如何在Nginx节点服务器上配置Websocket安全(wss)?

问题描述 投票:0回答:1

我尝试在Nginx服务器上配置Websocket代理,但是很遗憾,我没有使它正常工作。我读过各种表格,但不能摆脱它。我认为这与客户端与服务器之间的连接有关。我的电脑在本地om一切正常

客户代码:

 var port = new osc.WebSocketPort({
          url: "wss://circusfamilyprojects.nl/"
        }); 

服务器代码:

var wss = new WebSocket.Server({
    port: 8083
});

这是我在Nginx中的配置

 # custom code for hop by hop headers
    map $http_upgrade $connection_upgrade {
        default upgrade;
        ''      close;
    }


    #custom code for connection with websocket this is the port on the server
     upstream websocket  {
        server 178.62.209.37:8083;
    }

server {

      listen [::]:443 ssl ipv6only=on; # managed by Certbot
      listen 443 ssl; # managed by Certbot
      ssl_certificate /etc/letsencrypt/live/circusfamilyprojects.nl/fullchain.pem; # managed by Cert$
      ssl_certificate_key /etc/letsencrypt/live/circusfamilyprojects.nl/privkey.pem; # managed by Ce$
      include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
      ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

       root /var/www/html/vue/cfdomotica/server/public;

        # Add index.php to the list if you are using PHP
        index index.html index.htm index.nginx-debian.html;

       server_name  circusfamilyprojects.nl www.circusfmailyprojects.nl; # managed by Certbot

      location / {
            proxy_pass http://websocket;
            proxy_set_header HOST $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
            proxy_pass_request_headers on;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection $connection_upgrade;

        }
}

server {
    if ($host = www.circusfamilyprojects.nl) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    if ($host = circusfamilyprojects.nl) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


        listen 8080 ;
        listen [::]:8080 ;
    server_name  circusfamilyprojects.nl;
    return 404; # managed by Certbot
}

在我的浏览器中,我收到消息“状态码:426需要升级”,希望有人可以帮助我,谢谢!!

我尝试在Nginx服务器上配置Websocket代理,但是很遗憾,我没有使它正常工作。我读过各种表格,但不能摆脱它。我认为这与...

ssl nginx websocket certbot
1个回答
0
投票

我通过将端口443的服务器块和WebSocket客户端的服务器块分开来解决了自己的问题。我在端口8086上为客户端做了服务器块。

© www.soinside.com 2019 - 2024. All rights reserved.