使用ngix和ssl实现的反向代理表达失败

时间:2016-12-01 14:29:26

标签: node.js express ssl nginx proxy

我尝试在我的node.js应用程序中实现ssl但失败了。这是我的app.js

https://gist.github.com/eldyvoon/7a1df560fd9d13da74d090e28f7ee801

在开发中(localhost)我得到'你的连接不是私密'错误。我认为这是Chrome的问题。

所以我尝试将它部署到我的ubuntu服务器,我使用nginx代理为我的node.js应用程序,我的配置如下

server {

    listen 80;

    server_name mysite.com;

    location / {
        proxy_pass http://localhost:3001;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header Host $host;
    }

}

但是mysite.com拒绝连接。节点的控制台中没有错误。我坚持了几天,需要帮助。请注意,在尝试实施ssl之前,我的网站运行正常。

1 个答案:

答案 0 :(得分:0)

您需要侦听端口443并配置nginx以使用某些证书。

类似的东西:

server {
    listen 443;
    server_name example.com;
    add_header Strict-Transport-Security "max-age=3600";
    ssl on;
    ssl_certificate /.../chained2.pem;
    ssl_certificate_key /.../domain.key;
    ssl_session_timeout 5m;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:DHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA;
    ssl_session_cache shared:SSL:50m;
    ssl_prefer_server_ciphers on;

    location / {
        proxy_pass http://localhost:3001;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header Host $host;
    }

}

为.pem和.key文件添加正确的路径。您可以从Let's Encrypt免费获得证书。