0


前端 webSocket配置代理

vue, react. nginx 配置反向代理,解决跨域问题

前端请求

如果配置了 wss 协议, 可以将ws 替换为 wss

这里和我们通常使用的方式不同websocket 需要传入完整的地址,然后才能去做代理

  1. let url = `${location.protocol === 'https' ? 'wss' : 'ws'}://${location.host}/ws/socket/io`;
  2. const socket = new WebSocket(url);

vite.config.ts给 将 proxy

如果配置了 wss 协议, 可以将ws 替换为 wss

  1. "/ws": {
  2. target: "ws://localhost:8888", // 后端地址
  3. changeOrigin: true, //支持跨域
  4. ws: true, // 是否启用WebSocket代理
  5. rewrite: (path) => path.replace(/^\/ws/, ""), // 重写
  6. },

服务器 nginx 代理配置 ,配置后刷新就好了

  1. # nginx配置websocket
  2. location /ws/ {
  3. rewrite /ws/(.*) /$1 break;
  4. proxy_pass http://127.0.0.1:7000/; #websocket地址
  5. proxy_http_version 1.1;
  6. proxy_set_header Host $host;
  7. proxy_set_header X-Real-IP $remote_addr;
  8. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  9. proxy_read_timeout 120s;
  10. proxy_set_header Upgrade websocket;
  11. proxy_set_header Connection Upgrade;
  12. }

大概就这样,如果有问题后面胡补充@


本文转载自: https://blog.csdn.net/liyu_ya/article/details/134874634
版权归原作者 鲤小圈 所有, 如有侵权,请联系我们删除。

“前端 webSocket配置代理”的评论:

还没有评论