所以说我有一个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证书.