【发布时间】:2019-12-02 00:31:44
【问题描述】:
有没有办法查明用户是否拒绝或允许媒体设备的权限(例如: Firefox 中的麦克风、相机)?在 Chrome 中,我可以使用 navigator.permissions.query 进行检查,但在 Firefox 中失败并显示“TypeError”。
navigator.permissions.query({name:"microphone"}).then(function(promise) {
if ( promise && promise.state ) {
console.log(promise.state); //"granted", "prompt" or "rejected"
}
});
//in Firefox, It throws the error "TypeError: 'name' member of PermissionDescriptor '' is not a valid value for enumeration PermissionName"
由于某种原因,我无法通过 try catch 块捕获上述错误。所以我想知道为什么我不能在 try catch 块中捕捉到这个错误以及是否有替代方法。
用例
我的应用程序具有语音识别功能。在用户遇到寻求访问麦克风的实际“系统对话框”之前,我需要显示“预许可弹出窗口”。这个“预权限弹出”背后的想法是为用户提供应用程序需要访问权限的上下文。如果用户已经授予/拒绝访问权限,则不需要弹出预许可。所以我需要检查麦克风的 权限状态并在需要时显示弹出窗口。
【问题讨论】:
-
嗨,这可能是一个安全问题吗? getUserMedia 仅适用于安全上下文。除非您在本地主机中,否则它不会在 http 中工作。当 window.onload blog.addpipe.com/common-getusermedia-errors 时也尝试运行本文中的代码
-
@louiekim 我也通过 https 看到了这个问题。看来 navigator.permissions.query 在 firefox 和 edge 中有限制。
-
stackoverflow.com/questions/53147944 虽然对于您的情况可能会有一些破解,例如
(await navigator.mediaDevices.enumerateDevices()).filter( ({kind}) => "audioinput" )[0].label !== ""可以告诉我们设备的权限是否已“授予”,尽管从我的测试来看它似乎不太可靠...另请注意,根据用户的设置,UA 可能总是要求权限,因此解释您的用例可能对这个问题有益。 -
@Kaiido 我包含了用例。
-
总是显示消息?或者,如果您真的认为它太麻烦,请将 cookie/pref 存储在 localStorage 中,以便每个用户仅显示一次。
标签: javascript html firefox getusermedia mediadevices