node.js - 在 express.js 上启用 HTTPS

标签 node.js https express

我正在尝试让 HTTPS 在 node 的 express.js 上运行,但我无法弄清楚。

这是我的 app.js 代码。

var express = require('express');
var fs = require('fs');

var privateKey = fs.readFileSync('sslcert/server.key');
var certificate = fs.readFileSync('sslcert/server.crt');

var credentials = {key: privateKey, cert: certificate};


var app = express.createServer(credentials);

app.get('/', function(req,res) {
    res.send('hello');
});

app.listen(8000);

当我运行它时,它似乎只响应 HTTP 请求。

我编写了简单的基于 node.js 的 HTTPS 应用程序:

var   fs = require("fs"),
      http = require("https");

var privateKey = fs.readFileSync('sslcert/server.key').toString();
var certificate = fs.readFileSync('sslcert/server.crt').toString();

var credentials = {key: privateKey, cert: certificate};

var server = http.createServer(credentials,function (req, res) {
  res.writeHead(200, {'Content-Type': 'text/plain'});
  res.end('Hello World\n');
});

server.listen(8000);

当我运行这个应用程序时,它确实响应 HTTPS 请求。请注意,我认为 fs 结果上的 toString() 并不重要,因为我使用了两者的组合,但仍然没有 es bueno。


编辑添加:

对于生产系统,您最好使用 Nginx 或 HAProxy 将请求代理到您的 nodejs 应用程序。您可以设置 nginx 来处理 ssl 请求,然后将 http 与您的 Node app.js 对话。

编辑添加(2015 年 4 月 6 日)

对于使用 AWS 的系统,您最好使用 EC2 弹性负载均衡器来处理 SSL 终止,并允许定期 HTTP 流量到您的 EC2 Web 服务器。为了进一步提高安全性,请设置您的安全组,以便只允许 ELB 将 HTTP 流量发送到 EC2 实例,这将防止外部未加密的 HTTP 流量到达您的计算机。


最佳答案

在 express.js(从版本 3 开始)中,您应该使用该语法:

var fs = require('fs');
var http = require('http');
var https = require('https');
var privateKey  = fs.readFileSync('sslcert/server.key', 'utf8');
var certificate = fs.readFileSync('sslcert/server.crt', 'utf8');

var credentials = {key: privateKey, cert: certificate};
var express = require('express');
var app = express();

// your express configuration here

var httpServer = http.createServer(app);
var httpsServer = https.createServer(credentials, app);

httpServer.listen(8080);
httpsServer.listen(8443);

这样你就可以为本地 http/https 服务器提供快速中间件

如果您希望您的应用在 1024 以下的端口上运行,您需要使用 sudo 命令(不推荐)或使用反向代理(例如 nginx、haproxy)。

关于node.js - 在 express.js 上启用 HTTPS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11744975/

相关文章:

ssl - 我可以在 mean.io 的什么地方设置我的 ssl 证书?

node.js - 使用express-fileUpload上传文件错误

javascript - 如何在服务器上手动取消 XMLHttpRequest 文件上传(流)

javascript - 如何在 Express.js 中使用 Less?

node.js - 什么是 ELF——换行?

node.js - 如何在 typescript 中获得与express的Post方法相同的数据类型

node.js - 找不到模块“验证器”

node.js - Node redis,变量在客户端之间共享?

php - 欺骗 $_SERVER ['HTTPS' ] 在本地 wamp-server 上进行测试

asp.net - 使用 IE 通过 https(SSL) 导出到 excel 在 asp.net 网站中不起作用