我尝试在我的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之前,我的网站运行正常。
答案 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免费获得证书。