我的环境
- 亚马逊(AWS)的一个ubuntu虚拟机.
- node
- openssl
生成证书
输入如下命令会在你的当前文件夹生成localhost.key和localhost.cert.
其中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
两个文件.
更新
如果不想用密码保护私钥,加上-nodes.
加上-subj '/CN=localhost'
可以设置certificate的内容. 将其中的localhost
替换成你的域名.
代码
想要运行如下代码,需要先安装包
创建文件index.js,内容如下.
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('/',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' );
} );
启动服务器
访问
浏览器中输入http://xxx.compute.amazonaws.com/
就会以80端口访问HTTP服务器. 显示hi HTTP
.
输入https://xxx.compute.amazonaws.com/
就会以443端口访问HTTPS服务器,显示hi HTTPS
.
参考