浏览器https时不支持 调用媒体信息,生成和添加本地证书

前情:

 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 -newca   ----  newca是参数 有不同参数 按需要查询使用

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

浏览器https时不支持 调用媒体信息,生成和添加本地证书_第1张图片

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

cacert.pem和private/cakey.pem分别为ca根证书和ca证书私钥   ----生成client的证书时会检查

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)