欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

浏览器https时不支持 调用媒体信息

程序员文章站 2022-05-15 23:45:32
...

前情:

 MediaDevices 的方法 enumerateDevices(): 请求一个可用的媒体输入和输出设备的列表
navigator.mediaDevices.enumerateDevices();js调用获取媒体信息,浏览器不支持所以未获取到。是因为chrome需要https来访问。​

解决方法:虚拟机ubuntu需要生成本地的证书,key,pem,来实现https访问。

1.openssl

 没安装先安装,可以看看有没有/usr/lib/ssl

2.下面生成ca证书

创建一个你放证书的目录:$ mkdir work/cert

 

将之前ssl下的文件 copy到新创建的证书目录下:$ cp /usr/lib/ssl/misc/CA.sh .

继续在work/cert目录下  $ CA.sh xxxxcert

出来如下界面 输入phrase的时候4-1024位 本地用简单点就行

浏览器https时不支持 调用媒体信息

上面的成功后,目录下生成demoCA里面有一些文件 

cacert.pem和private/cakey.pem分别为ca根证书和ca证书私钥

3 .生成服务器证书

    1)    生成私钥:        openssl genrsa -des3 -out server.key 1024

    2)    生成csr文件:   openssl req -new -key server.key -out server.csr

    3)    生成证书&签名:    openssl ca -in server.csr -out server.crt (出错把demoCA下的index.txt删了,再touch一个新的)

 

4.生成客户端证书

    1)    生成私钥:        openssl genrsa -des3 -out client.key 1024

    2)    生成csr文件:   openssl req -new -key client.key -out client.csr

    3)    生成证书&签名:        openssl ca -in client.csr -out client.crt(出错把demoCA下的index.txt删了,再touch一个新的)

key : fs.readFileSync('./cert/server.key'), 
cert: fs.readFileSync('./cert/server.crt'),
passphrase:'之前填写的字符'

 

再使用浏览器访问本地 可使用https了

相关标签: webrtc