欢迎光临,了解微信小程序开发,就上易用通!

Nodejs+Express创建HTTPS服务器+WS模块创建加密的WS服务

发布:2018-01-25 15:11浏览: 来源:网络 作者:tianshu

第一部分:Nodejs+Express创建HTTPS服务器:
 
为了使我的Nodejs服务器提供HTTPS服务,学习了一下如何利用express创建https服务器,现记录如下。

1. Http与Https
介绍
  • HTTP: 超文本传输协议 (Hypertext transfer protocol) 是一种详细规定了浏览器和万维网服务器之间互相通信的规则,通过因特网传送万维网文档的数据传送协议。
  • HTTPS:(Hypertext Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入SSL层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。 它是一个URI scheme(抽象标识符体系),句法类同http:体系。用于安全的HTTP数据传输。https:URL表明它使用了HTTP,但HTTPS存在不同于HTTP的默认端口及一个加密/身份验证层(在HTTP与TCP之间)。这个系统的最初研发由网景公司进行,提供了身份验证与加密通讯方法,现在它被广泛用于万维网上安全敏感的通讯,例如交易支付方面。
区别
  • https协议需要到ca申请证书,一般免费证书很少,需要交费。
  • http是超文本传输协议,信息是明文传输,https 则是具有安全性的ssl加密传输协议。
  • http和https使用的是完全不同的连接方式,用的端口也不一样,前者是80,后者是443。
  • http的连接很简单,是无状态的;HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,比http协议安全。
2. 使用Express创建Https服务器
在Nodejs中,我们可以通过内置的https库,来实现HTTPS服务器。
  • 首先,我们需要利用openssl生成证书文件:
#生成私钥key文件openssl genrsa 1024 > /path/to/private.pem//#通过私钥文件生成CSR证书签名openssl req -new -key /path/to/private.pem -out csr.pem//#通过私钥文件和CSR证书签名生成证书文件openssl x509 -req -days 365 -in csr.pem -signkey /path/to/private.pem -out /path/to/file.crt
新生成了三个文件:
  • private.pem: 私钥
  • csr.pem: CSR证书签名
  • file.crt: 证书文件
  • 修改Nodejs启动文件server.js:

  1. var app = require('express')();
  2. var fs = require('fs');
  3. var http = require('http');
  4. var https = require('https');
  5. var privateKey  = fs.readFileSync('/path/to/private.pem', 'utf8'),
  6. var certificate = fs.readFileSync('/path/to/file.crt', 'utf8');
  7. var credentials = {key: privateKey, cert: certificate};
  8.  
  9. var httpServer = http.createServer(app);
  10. var httpsServer = https.createServer(credentials, app);
  11. var PORT = 18080;
  12. var SSLPORT = 18081;
  13.  
  14. httpServer.listen(PORT, function() {
  15.     console.log('HTTP Server is running on: https://localhost:%s', PORT);
  16. });
  17. httpsServer.listen(SSLPORT, function() {
  18.     console.log('HTTPS Server is running on: https://localhost:%s', SSLPORT);
  19. });
  20.  
  21. // Welcome
  22. app.get('/', function(req, res) {
  23.     if(req.protocol === 'https') {
  24.         res.status(200).send('Welcome to Safety Land!');
  25.     }
  26.     else {
  27.         res.status(200).send('Welcome!');
  28.     }
  29. });


  • 启动服务器:$ node server.jsHTTP Server is running on: https://localhost:18080HTTPS Server is running on: https://localhost:18081
  • 打开浏览器
HTTP访问:
Nodejs+Express创建HTTPS服务器+WS模块创建加密的WS服务(图1)



HTTPS访问:
Nodejs+Express创建HTTPS服务器+WS模块创建加密的WS服务(图2)



查看证书:
Nodejs+Express创建HTTPS服务器+WS模块创建加密的WS服务(图3)



由于我们证书是自己创建的,没有经过第三方机构的验证,所以会出现警告的提示。有条件的可以去godaddy SSL Cert官网申请,当然挺贵的,免费党就选择了WoSign,也是可以的,详情见[./]https://weixin.frankfan.me]。
Nodejs+Express创建HTTPS服务器+WS模块创建加密的WS服务(图4)




至此,我们成功的利用Nodejs内置https和express创建了HTTPS服务器。
参考:
https://blog.fens.me/nodejs-https-server/
https://heyrod.com/snippet/s/node-https-ssl.html

第二部分:用WS模块创建加密的WS服务(WSS):

node的ws模块可以很方便地创建一个单纯的标准websocket服务,但是对于创建wss服务并没有提供一个独立的方法,还是使用创建ws服务的方法,在传入参数对象里加了个自定义的https服务。

 

也不知道是我找错了文档还是官方文档就那么简洁,不过readme文件写的文档的确是这个→doc/ws.md,然后我研究了好几天还翻了遍它的源码和examples才终于理解了这个文档。


示例

  1. var https=require('https');
  2. var ws=require('ws');
  3. var fs=require('fs');
  4. var keypath=process.cwd()+'/server.key';//我把秘钥文件放在运行命令的目录下测试
  5. var certpath=process.cwd()+'/server.crt';//console.log(keypath);
  6. //console.log(certpath);
  7.  
  8. var options = {
  9.   key: fs.readFileSync(keypath),
  10.   cert: fs.readFileSync(certpath),
  11.   passphrase:'1234'//如果秘钥文件有密码的话,用这个属性设置密码
  12. };
  13.  
  14. var server=https.createServer(options, function (req, res) {//要是单纯的https连接的话就会返回这个东西
  15.     res.writeHead(403);//403即可
  16.     res.end("This is a  WebSockets server!\n");
  17. }).listen(25550);
  18.  
  19.  
  20. var wss = new ws.Server( { server: server } );//把创建好的https服务器丢进websocket的创建函数里,ws会用这个服务器来创建wss服务
  21. //同样,如果丢进去的是个http服务的话那么创建出来的还是无加密的ws服务
  22. wss.on( 'connection', function ( wsConnect ) {
  23.     wsConnect.on( 'message', function ( message ) {
  24.         console.log( message );
  25.     });
  26. });

wss创建出来,其余的操作和普通的ws服务都是完全一样的





免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。