我正在运行一个NodeJS应用程序,并使用运行在端口5000上的pm2进行部署,这可以很好地处理http请求。为了让https正常工作,我在nginx中创建了一个反向代理来转发端口5001上的https请求,以转发到端口5000。如果我禁用SSL,它工作得很好,http请求被正确地从端口5001转发到端口5000,但https只适用于GET方法,而不适用于POST方法。
server {
listen 5001 default_server;
ssl on;
ssl_certificate /home/ubuntu/xyz.crt;
ssl_certificate_key /home/ubuntu/xyz.key;
server_name mydomain.com www.mydomain.com;
root ~/mynodeapp; location / {
proxy_pass http://127.0.0.1:5000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade; proxy_buffering off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
} 我需要能够通过端口5001通过SSL调用在端口5000上运行的API端点
发布于 2019-10-10 03:17:00
proxy\_set\_header Upgrade $http\_upgrade; proxy\_set\_header Connection 'upgrade';
我不知道这些报头的用途是什么,因为它们应该只在转发WebSockets时使用--这也意味着只在GET的上下文中使用。因此,它可能是错误的,并可能解释您所遇到的问题。
https://stackoverflow.com/questions/58310179
复制相似问题