Nodejs搭建wss服务器教程
本文为大家分享了Nodejs搭建wss服务器的教程,供大家参考,具体内容如下
首先使用OpenSSL创建自签名证书:
#生成私钥key文件 opensslgenrsa1024>/path/to/private.pem // #通过私钥文件生成CSR证书签名 opensslreq-new-key/path/to/private.pem-outcsr.pem // #通过私钥文件和CSR证书签名生成证书文件 opensslx509-req-days365-incsr.pem-signkey/path/to/private.pem-out/path/to/file.crt
使用ws模块创建wss服务器:
varhttps=require('https');
varws=require('ws');
varfs=require('fs');
varkeypath=process.cwd()+'/server.key';//我把秘钥文件放在运行命令的目录下测试
varcertpath=process.cwd()+'/server.crt';//console.log(keypath);
//console.log(certpath);
varoptions={
key:fs.readFileSync(keypath),
cert:fs.readFileSync(certpath),
passphrase:'1234'//如果秘钥文件有密码的话,用这个属性设置密码
};
varserver=https.createServer(options,function(req,res){//要是单纯的https连接的话就会返回这个东西
res.writeHead(403);//403即可
res.end("ThisisaWebSocketsserver!\n");
}).listen(15449);
varwss=newws.Server({server:server});//把创建好的https服务器丢进websocket的创建函数里,ws会用这个服务器来创建wss服务
//同样,如果丢进去的是个http服务的话那么创建出来的还是无加密的ws服务
wss.on('connection',function(wsConnect){
wsConnect.on('message',function(message){
console.log(message);
});
});
客户端链接:
varws=newWebSocket('wss://localhost:15449/',{
protocolVersion:8,
origin:'https://localhost:15449',
rejectUnauthorized:false//重要,自签名证书只能这样设了。CA颁发的受信任证书就不需要了
});
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。