我正在尝试为我的三星Gear S3前沿创建一个tizen中的Web应用程序。但是,我收到"权限被拒绝"安全错误。
我有:
<tizen:privilege name="http://developer.samsung.com/privilege/healthinfo"/>
和
<tizen:privilege name="http://tizen.org/privilege/healthinfo"/>
在我的配置中启用.xml。
如果我在设置中为应用程序启用传感器权限,我可以获得心率读数,但每次编译和上传较新版本时它都会重置,这相当乏味。
这是我的JS代码,有点像从GEAR S3心率监测器(HRM(检索数据到手机或服务器:
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"传感器,如果不手动设置权限,我也无法访问它。
如何解决此问题?
我自己已经找到了答案,经过一些更有创意的网络搜索。它是使用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();
希望这对任何人都有帮助。如果您需要更多信息,我创建了一个 ES2016 npm/webpack 项目,请访问 https://github.com/reinvantveer/Axyll