您的位置:首页 > 其它

WebRTC getUserMedia()获取流失败的原因查询及解决

2016-08-05 17:06 716 查看

目录

目录
getUserMedia API

参数
successCallback

errorCallback

错误查询方法

原因及解决方法

最近调试WebRTC,客户端的Chrome浏览器都无法获取视频流,原以为是Chrome版本太低,升级了版本,也不行,于是查阅了相关API…

getUserMedia API:

navigator.getUserMedia ( constraints, successCallback, errorCallback );

参数

参数是否必须描述
constraints必须successCallback中传入的 LocalMediaStream对象所支持的媒体类型。
successCallback必须当应用中传递LocalMediaStream对象时触发的函数。
errorCallback可选当调用媒体设备失败时触发的函数.

successCallback:

getUserMedia 函数会调用successCallback 并传入LocalMediaStream 对象,这个对象包含媒体流。

errorCallback:

错误描述
PERMISSION_DENIED用户拒绝了浏览器请求媒体的权限
NOT_SUPPORTED_ERRORconstraint中指定的媒体类型不被支持
MANDATORY_UNSATISFIED_ERROR指定的媒体类型未接收到媒体流

错误查询方法:

errorCallback=function(error) {

alert(error.name || error);

利用这行代码查询错误原因。我的错误信息提示为:PERMISSION_DENIED

原因及解决方法:

Chrome 47以后,getUserMedia API只能允许来自“安全可信”的客户端的视频音频请求,如HTTPS和本地的Localhost。 例如:https://192.168.1.2:8080

localhost是唯一不用https的域名。

因此,解决这个问题一个方法是让自己的Web支持HTTPS,还有一个方法使用旧版本的Chrome。如Chrome 46等。

希望本文对大家能有帮助;关于Web如何实现HTTPS,后续…
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  WebRTC chrome
相关文章推荐