很多時候我們訪問服務端接口需要使用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 編輯過