【bug】websocket协议不兼容导致的一个奇怪问题

最近在开发一个基于websocket的实时语音转文字小工具【就是这个】,出现了一个奇怪的现象:

前端代码

复制代码
import { io } from 'socket.io-client';

...

await this.connectWebSocket();

...

connectWebSocket() {
        return new Promise((resolve, reject) => {
            this.socket = io('ws://localhost:8080', {
                path: '/ws',
                transports: ['websocket'],
                auth: {
                    token: '11223333'
                },
            });
            
            this.socket.on('connect', () => {
            console.log('WebSocket连接成功');
            this.status = '已连接服务器,正在录音...';
            });
            
            this.socket.on('disconnect', () => {
            console.log('WebSocket断开连接');
            this.status = '服务器连接已断开';
            });
            
            this.socket.on('transcript', (data) => {
            console.log('收到转写结果:', data);
            this.processTranscript(data);
            });
            
            this.socket.on('error', (error) => {
            console.error('WebSocket错误:', error);
            this.status = `连接错误: ${error.message}`;
            });
        });
      },

H5页面现象

后端日志:

21:48:33.774 [nioEventLoopGroup-2-1] INFO i.n.handler.logging.LoggingHandler - [id: 0xc034c3bc, L:/[0:0:0:0:0:0:0:0]:8080] READ: [id: 0xc4e5890d, L:/[0:0:0:0:0:0:0:1]:8080 - R:/[0:0:0:0:0:0:0:1]:50069]

21:48:33.777 [nioEventLoopGroup-2-1] INFO i.n.handler.logging.LoggingHandler - [id: 0xc034c3bc, L:/[0:0:0:0:0:0:0:0]:8080] READ COMPLETE

21:48:34.218 [nioEventLoopGroup-2-1] INFO i.n.handler.logging.LoggingHandler - [id: 0xc034c3bc, L:/[0:0:0:0:0:0:0:0]:8080] READ: [id: 0x4170a495, L:/127.0.0.1:8080 - R:/127.0.0.1:50072]

21:48:34.219 [nioEventLoopGroup-2-1] INFO i.n.handler.logging.LoggingHandler - [id: 0xc034c3bc, L:/[0:0:0:0:0:0:0:0]:8080] READ COMPLETE

核心原因:

  1. 前端 使用的是 Socket.IO 协议 (基于 Engine.IO,带 EIO=4 参数)。

  2. 后端 实现的是 原生 WebSocket (通过 Netty 的 WebSocketServerProtocolHandler)。

    • 这两者 协议不兼容Socket.IO 客户端无法直接连接原生 WebSocket 服务。

修改方案

特性 Socket.IO 原生 WebSocket
协议 基于 Engine.IO,封装了 WebSocket + HTTP 长轮询 纯 WebSocket(RFC 6455)
兼容性 自动降级兼容旧浏览器(IE9+) 仅支持现代浏览器(IE10+)
功能扩展 内置房间、广播、自动重连、ACK 确认等 需手动实现
数据传输 支持二进制(需配置)和结构化数据(JSON) 直接支持二进制和文本
连接复杂度 高(握手阶段较长) 低(直接建立 WS 连接)
适用场景 实时性要求高、需复杂功能(如聊天室) 轻量级、低延迟(如音频流、游戏)

我经过权衡后决定使用原生的WebSocket

修改后的H5代码如下:

复制代码
connectWebSocket() {
        return new Promise((resolve, reject) => {
            const ws = new WebSocket('ws://localhost:8080/ws');

            ws.onopen = () => {
                console.log('WebSocket连接成功');
                this.status = '已连接服务器,正在录音...';
                this.socket = ws;
                resolve(); // ✅ 必须 resolve,才能继续录音
            };

            ws.onclose = () => {
                console.log('WebSocket断开连接');
                this.status = '服务器连接已断开';
            };

            ws.onmessage = (event) => {
                console.log('收到转写结果:', event.data);
                this.processTranscript(event.data);
            };

            ws.onerror = (error) => {
                console.error('WebSocket错误:', error);
                this.status = '连接错误';
                reject(error);
            };
        });
      },

完美运行!

相关推荐
Cc_Debugger11 小时前
【饿了么plus-table】开启多选时,点击下面的单选按钮,页面显示是全选的样子,bug
bug
龙卷风卷云12 小时前
【BUG】Nginx使用upstream后端接口报 400
运维·nginx·bug
jiayi_19992 天前
[bug] unsupported GNU version! gcc versions later than 12 are not supported!
服务器·bug·gnu
管二狗赶快去工作!3 天前
体系结构论文(九十三):LLM-Aided Compilation for Tensor Accelerators
人工智能·语言模型·自然语言处理·bug·体系结构
查古穆3 天前
LLM的“小bug”:聊聊幻觉是什么,以及如何有效规避免
人工智能·bug
程序员 沐阳3 天前
Git 二分法精准定位 Bug:从原理到实战,让调试效率起飞
git·elasticsearch·bug
软泡芙3 天前
【Bug】ReactiveUI WPF绑定中依赖属性不更新的问题分析与解决方案
java·bug·wpf
Yiyi_Coding4 天前
BUG列表:如何定位线上 OOM ?
java·linux·bug
csdn_aspnet6 天前
Git二分法精准定位Bug,分享用git bisect快速锁定引入缺陷的提交,提升调试效率
git·bug·二分查找
R6bandito_6 天前
自实现FLASH读取函数中的隐式类型转换bug踩坑记录
c语言·开发语言·经验分享·stm32·单片机·mcu·bug