Nginx配置wss代理,实现websocket服务端访问是经过SSL认证的wss协议
|
admin
2025年8月11日 9:18
本文热度 1283
|
很多时候我们访问服务端接口需要使用https的方式,比如微信小程序嵌入H5页面,地址必须是https。如果里面用到websocket的话,也同样必须是经过SSL认证的wss协议。
服务端肯定是无法直接支持的,服务端默认只会支持ws协议。如果要支持wss,我们可以仿照https的使用方式,也用nginx配置一个代理。那么前提就是已经使用nginx配置好了SSL证书,像下面这样:server { listen 443 ssl; server_name test.example.com;
ssl_certificate /certs/cert.pem; ssl_certificate_key /certs/cert.key;
location /api { proxy_pass http://127.0.0.1:8082; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; }}
这里配置了ssl证书,以及服务端/api的反向代理,假设websocket的端点是/ws,那么我们可以类似的配置一个代理,如下:server { listen 443 ssl; server_name test.example.com;
ssl_certificate /certs/cert.pem; ssl_certificate_key /certs/cert.key;
location /api { proxy_pass http://127.0.0.1:8082; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; }
location /ws { proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection upgrade;proxy_pass http://127.0.0.1:8082; proxy_set_header Host $host;proxy_set_header X-Real_IP $remote_addr;proxy_set_header X-Forwarded-For $remote_addr:$remote_port;proxy_redirect off;client_max_body_size 50m;proxy_connect_timeout 600;proxy_read_timeout 600;proxy_send_timeout 600; }}
这样,我们就可以使用wss://test.example.com/ws/xxx来连接websocket服务端了!
该文章在 2025/8/11 11:19:44 编辑过