前端 webSocket配置代理

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

前端请求

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

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

javascript 复制代码
  let url = `${location.protocol === 'https' ? 'wss' : 'ws'}://${location.host}/ws/socket/io`;
  const socket = new WebSocket(url);

vite.config.ts给 将 proxy

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

javascript 复制代码
   "/ws": {
        target: "ws://localhost:8888", // 后端地址
        changeOrigin: true, //支持跨域
        ws: true, // 是否启用WebSocket代理
        rewrite: (path) => path.replace(/^\/ws/, ""), // 重写
      },

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

javascript 复制代码
        # nginx配置websocket
    location /ws/ {
        rewrite /ws/(.*) /$1 break;
         target: "ws://localhost:8888",  #websocket地址
        proxy_http_version 1.1;
        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_read_timeout 120s;
        proxy_set_header Upgrade websocket;
        proxy_set_header Connection Upgrade;
}

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

相关推荐
ayas123191 分钟前
CSS学习
前端·css·学习
人生在勤,不索何获-白大侠8 分钟前
day25——HTML & CSS 前端开发
前端·css·html
Running_C15 分钟前
Content-Type的几种类型
前端·面试
前端Hardy15 分钟前
10 分钟搞定婚礼小程序?我用 DeepSeek 把同学的作业卷成了范本!
前端·javascript·微信小程序
Tminihu17 分钟前
前端大文件上传的时候,采用切片上传的方式,如果断网了,应该如何处理
前端·javascript
颜酱19 分钟前
理解vue3中的compiler-core
前端·javascript·vue.js
果粒chenl30 分钟前
06-原型和原型链
前端·javascript·原型模式
谢尔登32 分钟前
【JavaScript】手写 Object.prototype.toString()
前端·javascript·原型模式
蓝倾34 分钟前
小红书获取笔记详情API接口调用操作指南
前端·api·fastapi
浩龙不eMo34 分钟前
设置单行省略号后不生效?你肯定忘记了这几点!
前端·css