node.js托管SSL?

Siy*_*ion 3 cloud-hosting node.js

所以说我有一个node.js应用程序,它同时托管HTTP和HTTPS服务器,如问题中所述:如何强制在Express.js中强制使用SSL/https

在我的代码中,我有以下内容:

// General configuration settings for production usage
app.configure(function () {
  app.set('port', process.env.PORT || 3000);
  app.set('sslport', process.env.SSLPORT || 4000);
  ...
}

http.createServer(app).listen(app.get('port'), function () {
  winston.info('Express server listening on port ' + app.get('port'));
});

var options = {
  key: fs.readFileSync('key.pem'),
  cert: fs.readFileSync('cert.pem')
};

https.createServer(options, app).listen(app.get('sslport'), function () {
  winston.info('Express server listening on port ' + app.get('sslport'));
});
Run Code Online (Sandbox Code Playgroud)

这适用于本地运行节点服务器.

但是,我想将我的网站发布到Azure网站,Heroku,Nodejitsu等云托管提供商.

所有云主机似乎都设置了一个process.env.PORT值,但只有一个.当我的HTTPS服务器被创建时,这通常会导致应用程序崩溃,因为PORT已经在使用/访问被拒绝/等等.

那么如何创建/托管一个只有一个端口的安全登录页面的网站呢?

小智 7

如果您使用Heroku,则无需在nodejs中指定端口即可获得SSL.您需要做的就是监听http请求的heroku PORT环境变量.上传到heroku后,您可以使用https(在443上)或http(在端口80上)来解决您的heroku应用.Heroku路由到您的服务器.

同样,如果使用EC2弹性负载平衡,您可以在负载均衡器上使用SSL终结,并再次使用http路由到侦听端口80的节点服务器.http://aws.amazon.com/elasticloadbalancing

在这两种情况下,您都可以根据需要使用自签名或正确的SSL证书.