未通过 https 在棘轮 Websocket 中获取响应标头

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

客户端网址

wss://stage.example.com/?token=xxxxxxxxxxxxxxxxxxxxx

Nginx 服务器块

        default upgrade;
        ''      close;
    }

server {
 
root /var/www/html/Example/public;

index index.php index.html;
 
server_name stage.example.com;
listen 80 ;
 

      error_log /home/ubuntu/error.log;
      access_log /home/ubuntu/access.log;
      client_max_body_size 10M;
      client_body_buffer_size     32k;
      client_header_buffer_size   8k;
      large_client_header_buffers 8 64k;
      fastcgi_buffers 16 16k;
      fastcgi_buffer_size 32k;
      proxy_buffer_size   128k;
      proxy_buffers   4 256k;
      proxy_busy_buffers_size   256k;


location / {

try_files $uri $uri/ /index.php?$query_string;
}

location /chat/ {
    proxy_pass http://127.0.0.1:8090;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;   
    proxy_set_header Connection $connection_upgrade;
    proxy_set_header Host $host;
}  

location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/var/run/php/php8.1-fpm.sock;
}

location ~ /\.(?!well-known).* {
        deny all;
    }

    listen [::]:443 ssl; # managed by Certbot
    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/stage.example.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/stage.example.com/privkey.pem; # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

}
server {
    if ($host = stage.example.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


listen 80 ;
listen [::]:80 ;
 
server_name stage.example.com;
    return 404; # managed by Certbot
}

(附图)。

getting request header

我在服务器上所做的更改。

nginx

我在 Nginx 中尝试了很多代理标头。以下是这些。即使这样我也没有得到回应。

#    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#    proxy_read_timeout 300s;
#    proxy_send_timeout 300s;
#    proxy_redirect off;
#    proxy_intercept_errors on;
#    proxy_cache_bypass $http_upgrade;
#    proxy_ssl_session_reuse off;
#    proxy_set_header X-Real-IP $remote_addr;
#    proxy_set_header X-NginX-Proxy true;
#    proxy_hide_header X-Powered-By;

 

    # Set WebSocket headers
#    proxy_set_header Sec-WebSocket-Key $http_sec_websocket_key;
#    proxy_set_header Accept-Encoding "gzip, deflate";
#    proxy_set_header Sec-WebSocket-Extensions "permessage-deflate";

主管

我正在使用 Supervisor 在服务器上的端口 8090 上运行ratchet WebSocket。

我检查过该端口是开放的。

如果有人指出问题将会很有帮助。预先感谢。

nginx nginx-reverse-proxy ratchet
© www.soinside.com 2019 - 2024. All rights reserved.