WebSocket connection to ‘...‘ failed: Invalid frame header
创始人
2024-11-05 08:09:57
0

问题描述

使用Vue创建客户端项目,项目中需要用到websocket协议与服务端通信,并为客户端请求配置代理,通过npm run serve启动时,控制台一直打印错误(大概1s一次),同样对应的服务端也会报错
在这里插入图片描述

vue.config.js

const { defineConfig } = require('@vue/cli-service') module.exports = defineConfig({   transpileDependencies: true,   devServer: {     port: 15436,     allowedHosts: 'all',     proxy: {       '^/ws': {         target: 'ws://127.0.0.1:15437',         ws: true,         changeOrigin: true,         // logLevel: 'debug' // 可选,用于调试代理连接       },     },     // webSocketServer: false,   } })  

原因分析:

提示:这里填写问题的分析:

使用 nodejs 启动前段服务的时候,不仅仅会启动一个http协议的 服务(浏览器可以直接访问的那个),还会默认启动一个 websocket服务(个人猜测用于 nodejs服务的热更新,参考 https://webpack.js.org/configuration/dev-server/
),这个默认的服务和你自己搭建的服务在通信格式上不同,它会每隔大概1s 发送一个 websocket帧,而由于这个帧的格式与服务端定义的格式不同,服务端不认识,于是定义为 Invalid frame header


解决方案:

提示:这里填写该问题的具体解决方案:

最易搜索到的解决方案:

  1. https://github.com/vuejs/vue-cli/issues/1850
  2. https://stackoverflow.com/questions/48487056/websocket-connection-to-failed-invalid-frame-header
  3. https://segmentfault.com/q/1010000023239199

上述方案的目的都是把 websocket代理关掉,但是如果关掉代理,客户端则不能正常连接服务端,核心的点在于关掉nodejs 启动默认的websocket服务

vue.config.js

const { defineConfig } = require('@vue/cli-service') module.exports = defineConfig({   transpileDependencies: true,   devServer: {     port: 15436,     allowedHosts: 'all',     proxy: {       '^/ws': {         target: 'ws://127.0.0.1:15437',         ws: true,         changeOrigin: true,         // logLevel: 'debug' // 可选,用于调试代理连接       },     },     webSocketServer: false,  // !!!!! 关键   } }) 

相关内容

热门资讯

2分钟辅助!科乐第三方辅助工具... 2分钟辅助!科乐第三方辅助工具(辅助挂)一直真的有辅助软件(存在有挂)该软件可以轻松地帮助玩家将科乐...
第二分钟了解!wejoker辅... 第二分钟了解!wejoker辅助软件视频,德普之星透视辅助软件是真的吗,学习教程(有挂解惑)所有人都...
5分钟辅助!方片十三张脚本(辅... 5分钟辅助!方片十三张脚本(辅助挂)原来有辅助插件(了解有挂)1、方片十三张脚本有没有辅助教程、方片...
第5分钟了解!wejoker黑... 第5分钟了解!wejoker黑侠辅助器,hardrock作弊,指南书教程(确实有挂)wejoker黑...
一分钟辅助!欢乐达人葫芦鱼辅助... 一分钟辅助!欢乐达人葫芦鱼辅助(辅助挂)总是是真的辅助app(了解有挂)1、完成欢乐达人葫芦鱼辅助辅...
三分钟了解!wepoker黑侠... 三分钟了解!wepoker黑侠辅助器正版下载,哈糖大菠萝有没有挂,绝活儿教程(真的有挂)1、上手简单...
第三分钟辅助!余干辅助软件哪个... 第三分钟辅助!余干辅助软件哪个好(辅助挂)一直有辅助攻略(确实有挂)1、玩家可以在余干辅助软件哪个好...
八分钟了解!wepoker辅助... 八分钟了解!wepoker辅助透视软件,werplan怎么作弊,总结教程(有挂教学)1、下载好wep...
第四分钟辅助!奇迹脚本辅助器手... 第四分钟辅助!奇迹脚本辅助器手机版(辅助挂)确实存在有辅助工具(有挂技巧)1.奇迹脚本辅助器手机版 ...
第5分钟了解!hhpoker透... 第5分钟了解!hhpoker透视脚本,wepoker有辅助插件吗,课程教程(真是有挂)一、wepok...