基于Netty的WebSocket自动解决拆包粘包问题

关注我的公众号:【编程朝花夕拾】,可获取首发内容。

01 引言

我们做了Websocket的案例,并没有像TCP协议一样处理拆包和粘包问题。Websocket基于Frame已经自动帮我们解决了拆包和粘包问题,我们一起来看看是怎么解决的!

02 WebSocketFrame

WebSocketFrame是 Netty 中用于表示 WebSocket 协议数据帧的抽象基类。在 WebSocket 通信中,所有数据(文本、二进制、控制帧等)都通过帧的形式进行传输。

核心属性

java 复制代码
// 帧的最终标志位(FIN)
private final boolean finalFragment;

// 保留位(RSV1, RSV2, RSV3)
private final int rsv;

finalFragment参数是解决拆包粘包的关键标志位。

03 处理流程

3.1 调用链

3.2 解码关键类

io.netty.handler.codec.http.websocketx.WebSocket08FrameDecoder

WebSocket协议定义了明确的帧格式,每个帧都有明确的边界标识:

关键字段:

  • FIN位(1位):标识是否是消息的最后一个帧
  • opcode(4位):操作码,标识帧类型(文本、二进制、控制帧等)
  • MASK位(1位):标识是否掩码
  • Payload length(7位):负载长度,自动扩展

WebSocket08FrameDecoder专门定义了解析帧的字段。

其中关键的代码块:

java 复制代码
byte b = in.readByte();
frameFinalFlag = (b & 0x80) != 0;

(b & 0x80) != 0是用于检测某个字节 b 的最高位(即第7位,从右往左数)是否为1。如果为1,则返回true,表示数据已经读完。这里正是解决拆包粘包的关键标志位。

3.3 整个解析流程

  • 长度字段解析:首先读取帧头部,解析payload长度
  • 动态读取:根据长度字段值,读取相应字节数的数据
  • 帧完整性检查:检查FIN位,确定消息是否结束
  • 消息聚合:对于分片消息(FIN=0),自动缓存和重组

04 小结

WebSocket的拆包粘包问题已经妥善解决,开发者只需要配置WebSocketServerProtocolHandler,Netty就会在合适的时机自动创建和配置WebSocket13FrameDecoder。为我们解决困扰,无需手动处理。

相关推荐
Coder_Boy_几秒前
企业级项目高并发监控场景-Spring Boot 集成 Graphite & InfluxDB 实战文档
java·spring boot·后端·系统架构
lang201509285 分钟前
Java EE并发工具:JSR 236详解
java·java-ee
毕设源码-朱学姐9 小时前
【开题答辩全过程】以 基于JavaWeb的网上家具商城设计与实现为例,包含答辩的问题和答案
java
C雨后彩虹10 小时前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
Stephen_Young11 小时前
32岁程序员猝死:让我想起了我曾经的加班经历,庆幸自己还活着
程序员·工控
java1234_小锋11 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试
2501_9445255412 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐12 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法
Filotimo_12 小时前
Tomcat的概念
java·tomcat