我正在尝试为我的Samsung Gear S3前沿创建一个Tizen网络应用程序。但是,我收到了“权限被拒绝”安全错误。
我有:
<tizen:privilege name="http://developer.samsung.com/privilege/healthinfo"/>
和
<tizen:privilege name="http://tizen.org/privilege/healthinfo"/>
在我的config.xml中启用了。
如果我在设置中启用了该应用程序的传感器权限,则可以获取心率读数,但是每次我编译并上传较新的版本时,它都会重置。
这是我的JS代码,按Retrieving Data from GEAR S3 Heart Rate Monitor (HRM) to Mobile or Server排序:
window.onload = function () {
// add eventListener for tizenhwkey
document.addEventListener('tizenhwkey', function(e) {
if(e.keyName === "back") {
try {
tizen.application.getCurrentApplication().exit();
} catch (ignore) {
}
}
});
// Sample code
var textbox = document.querySelector('.contents');
var box = document.querySelector('#textbox');
textbox.addEventListener("click", function(){
console.log('have box');
if (fetch === undefined) {
box.innerHTML = 'No such thing as fetch';
} else {
box.innerHTML = "We have fetch";
}
});
var sensors = tizen.sensorservice.getAvailableSensors();
console.log('Available sensors: ' + sensors.toString());
var heartRateData=0;
function onsuccessCB(hrmInfo) {
box.innerHTML = 'Heart rate: ' + hrmInfo.heartRate;
heartRateData = hrmInfo.heartRate;
// holding 15 seconds as HRM sensor needs some time
}
function onerrorCB(error) {
tizen.humanactivitymonitor.stop('HRM');
console.log('Error occurred: ' + error.message);
}
function onchangedCB(hrmInfo) {
//alert("onChanged...");
tizen.humanactivitymonitor.getHumanActivityData('HRM', onsuccessCB, onerrorCB);
}
tizen.humanactivitymonitor.start('HRM', onchangedCB);
};
我希望config.xml
设置能够照顾到权限,但是显然不会。该手表运行的是Tizen 4.0.0.2,并且运行的是“ HRM_RAW”传感器,如果不手动设置权限,我也无法访问该传感器。
我该如何解决这个问题?
答案 0 :(得分:1)
经过一些更具创造性的网络搜索,我想自己找到了答案。使用tizen.ppm.requestPermission()
(在https://developer.tizen.org/forums/web-application-development/security-exception-while-accessing-hrm
这将导致预期的行为。该应用程序在安装时通过可穿戴用户界面询问是否应授予该权限,以及该决定是否应为默认决定。
但是,我做了一些重构,因为您经常在应用中需要几个权限,而回调地狱就在附近。所以我围绕着tizen调用写了一个Promise包装器:
function requestPermit(uri) {
return new Promise(function(resolve, reject) {
tizen.ppm.requestPermission(uri,
function(success) => { resolve(success); },
function(error) => { reject(error); });
});
}
这允许我
function main() {
return permitRequester('http://tizen.org/privilege/healthinfo')
.then(function() { return permitRequester('http://developer.samsung.com/privilege/healthinfo'); })
.then(function() { return permitRequester('http://developer.samsung.com/privilege/medicalinfo'); })
.then(function() { return displayHeartRate(); })
.catch(function(err) { return console.log(err); });
}
window.onload = main();
您确实需要在项目中包含Promise库。我这样做是通过包括Promise polyfill来完成的,因为tizen Web应用程序本身并不支持此功能。希望这对任何人都有帮助。如果您需要更多信息,可以在https://github.com/reinvantveer/Axyll
上创建一个ES2016 npm / webpack项目。