我在AWS EC2实例上运行了一个节点Express应用程序。我可以使用 http: // ec2-xx-xxx-xxx-242.us-west-2.compute.amazonaws.com运行服务器并连接到快递应用
但是,当我使用 https
而不是 http
时,尽管我的实例上已打开端口443,但它无法正常工作。< / p>
有人可以建议我如何在我的快递应用上启用 https 。
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
//var httpsRedirect = require('express-https-redirect');
var index = require('./routes/index');
var users = require('./routes/users');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', index);
app.use('/users', users);
app.get('/hello', (req, res) => res.sendStatus(200));
app.get('/health-check', (req, res) => res.sendStatus(200));
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
// *** HERE I am setting my App to listen on port 443
//app.listen(8080);
app.listen(8443);
module.exports = app;
以下是我的EC2实例的规则,其中端口443对所有流量开放。
我已启用我在AWS EC2 Linux实例上从端口443转发到8443:
sudo iptables -A PREROUTING -t nat -i eth0 -p tcp --dport 443 -j REDIRECT --to-port 8443
打开Linux防火墙以允许端口443上的连接:
sudo iptables -A INPUT -p tcp -m tcp --sport 443 -j ACCEPT
sudo iptables -A OUTPUT -p tcp -m tcp --dport 443 -j ACCEPT
答案 0 :(得分:0)
这很容易,但需要一些时间来了解它通常如何工作。 这应该是一个很好的起点:https://www.sitepoint.com/configuring-nginx-ssl-node-js/
用几句话说: