我在使用 OpenTok 2 API 时遇到了一些麻烦。当我开始发布流并提示我允许或拒绝网站使用我的网络摄像头和麦克风时,如果我允许 allowed() 应该运行,但如果我拒绝 denied() 应该运行。

publisher.addEventListener('accessAllowed', allowed);
publisher.addEventListener('accessDenied', denied);

function allowed() {
    console.log('Allowed');
}

function denied() {
    console.log('Denied');
}

它在 Firefox 中按预期工作。但是,在 Chrome accessAllowed 中,accessDenied 无效。相反,我收到以下错误:
OT.Publisher.onStreamAvailableError PermissionDeniedError:
TB.exception :: title: Internal Error (2000) msg: Publisher failed to access camera/mic:

有任何想法吗?

最佳答案

这是 OpenTok 当前 JS 库中的一个错误。我确实有一个解决方法可以让你继续前进,当错误修复后我会回来更新。

var waiting = false;
publisher.addEventListener('accessAllowed', function() {
  waiting = false;
  allowed();
});
publisher.addEventListener('accessDenied', function() {
  waiting = false;
  denied();
});
publisher.addEventListener('accessDialogOpened', function() {
  waiting = true;
});
publisher.addEventListener('accessDialogClosed', function() {
  setTimeout(function() {
    if (waiting) {
      waiting = false;
      denied();
    }
  }, 0);
});

此解决方法略有限制,因为 Chrome 在拒绝访问一次然后再次访问该页面时有一些奇怪之处。如果用户没有改变他/她关于媒体权限的偏好,视频将继续被拒绝,“accessDialogOpened”甚至不会触发。我会通知团队并继续调查此事。

关于javascript - Chrome 中的 OpenTok accessDenied 问题,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21559016/

10-10 18:41