Express本地测试HTTPS的示例代码
我的环境
- 亚马逊(aws)的一个ubuntu虚拟机.
- node
- openssl
生成证书
输入如下命令会在你的当前文件夹生成localhost.key和localhost.cert.
openssl genrsa -out localhost.key 2048 openssl req -new -x509 -key localhost.key -out localhost.cert -days 3650 -subj /cn=localhost
其中localhost为域名. 想要换成别的域名就直接把上面的所有localhost替换成你的域名.
以我为例, 我的虚拟机的域名是xxx.compute.amazonaws.com
, 就以这个域名替换上面所有的localhost, 会生成, ec2-34-220-96-9.us-west-2.compute.amazonaws.com.key
和 ec2-34-220-96-9.us-west-2.compute.amazonaws.com.cert
两个文件.
更新
openssl req -x509 -newkey rsa:4096 -keyout key.pem -out cert.pem -days 365
如果不想用密码保护私钥, 加上-nodes.
加上-subj '/cn=localhost'
可以设置certificate的内容. 将其中的localhost
替换成你的域名.
参考:how to create a self-signed certificate with openssl?
代码
想要运行如下代码, 需要先安装包
npm init npm i -s https express
创建文件index.js, 内容如下.
#!/usr/bin/env node var https = require('https'); var fs = require('fs'); var express = require('express'); var host = 'xxx.compute.amazonaws.com'; // input you domain name here. var options = { key: fs.readfilesync( './' + host + '.key' ), cert: fs.readfilesync( './' + host + '.cert' ), requestcert: false, rejectunauthorized: false }; var httpapp = express(); var app = express(); app.get('/', function (req, res) { res.send('hi https'); }); httpapp.get('/', function (req, res) { res.send('hi http'); }); httpapp.listen(80, function () { console.log('http on 80'); }); var server = https.createserver( options, app ); server.listen( 443, function () { console.log( 'https on 443' ); } );
启动服务器
sudo node index.js
访问
浏览器中输入http://xxx.compute.amazonaws.com/
就会以80端口访问http服务器. 显示hi http
.
输入https://xxx.compute.amazonaws.com/
就会以443端口访问https服务器, 显示hi https
.
参考
self-signed, trusted certificates for node.js & express.js
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: Python笔记(十七):生成器
下一篇: 制作我们自己的Ebay(拍卖系统)(6)