所以说我有一个node.js应用程序,它同时托管HTTP和HTTPS服务器,如问题所述: How to force SSL / https in Express.js 在我的代码中,我有以下内容: // General configuration settings for production usageapp.confi
          在我的代码中,我有以下内容:
// 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'));
}); 
 这适用于本地运行节点服务器.
但是,我想将我的网站发布到Azure网站,Heroku,Nodejitsu等云托管提供商.
所有云主机似乎都设置了process.env.PORT值,但只设置了一个.当我的HTTPS服务器被创建时,这通常会导致应用程序崩溃,因为PORT已经在使用/访问被拒绝/等等.
那么如何创建/托管一个只有一个端口的安全登录页面的网站呢?
如果您使用Heroku,则无需在nodejs中指定端口即可获得SSL.您需要做的就是监听http请求的heroku PORT环境变量.上传到heroku后,您可以使用https(在443上)或http(在端口80上)来解决您的heroku应用. Heroku路由到您的服务器.同样,如果使用EC2弹性负载平衡,您可以在负载均衡器上使用SSL终结,并再次使用http路由到侦听端口80的节点服务器. http://aws.amazon.com/elasticloadbalancing
在这两种情况下,您都可以根据需要使用自签名或正确的SSL证书.
