Tcp粘包处理+无脑处理
大家都知道tcp会粘包的,比如你用1m去接收,它正常的单条数据是220,那么就会产生 5 到 6 个粘包体,我们只能打标识,用结束字符去分割处理。我写的一个类,仅供大家参考。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | public void Split( byte [] receiveData){ //整体的标识 List< int > end_index = new List< int >(); ///循环该粘包总体数据 for ( int i = 0; i < receiveData.Length; i++) { //最后4位直接检索 if (i + 3 == receiveData.Length) break ; //先找到粘包的结束标识 if (receiveData[i] == 0xaa && receiveData[i+1] == 0xaa && receiveData[i+2] == 0xaa && receiveData[i+3] == 0xaa) { end_index.Add(i + 3); //结束的标识 } } for ( int i = 0; i < end_index.Count; i++) { //判断是否有未结束的数据 if (redis_buffer_byte.Length != 0) { // 未结束的 + 第一个结束标识 byte [] RealData = new byte [end_index[i] + redis_buffer_byte.Length]; redis_buffer_byte.CopyTo(RealData, 0); receiveData.Skip(end_index[i]) .Take(end_index[i]+i).ToArray() .CopyTo(RealData, redis_buffer_byte.Length); //清空剩余byte redis_buffer_byte = new byte [] { }; if (RealData.Length == 108 || RealData.Length == receiveData.Length) return ; TCP_AddWireless(RealData); } else { //不证明是最后一个 if (i != end_index.Count -1) { // 前一个标识 + 后一个标拾 byte [] RealData = new byte [end_index[i+1] - end_index[i]]; //receiveData.CopyTo(RealData,end_index[i]); Array.Copy(receiveData,end_index[i],RealData,0, RealData.Length); if (RealData.Length == 108) return ; TCP_AddWireless(RealData); } else { //添加到剩余粘包队列中 byte [] RealData = new byte [receiveData.Length - end_index[i]]; redis_buffer_byte = RealData; } } } } |
这样调试起来还是很费劲的,如果是无脑的话哈哈哈,你用这个吧。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | public void Split_TcpData( byte [] receiveData) { for ( int i = 0; i < receiveData.Length; i++) { if (i + 3 == receiveData.Length) break ; if (receiveData[i] == 0xee && receiveData[i + 1] == 0xee && receiveData[i + 2] == 0xee && receiveData[i + 3] == 0xee) { for ( int y = i; y < receiveData.Length; y++) { if (y + 3 == receiveData.Length) break ; if (receiveData[y] == 0xaa && receiveData[y + 1] == 0xaa && receiveData[y + 2] == 0xaa && receiveData[y+ 3] == 0xaa) { byte [] RealData = new byte [y - i + 4 ]; Array.Copy(receiveData, i, RealData, 0,RealData.Length); if (RealData.Length > 146 && RealData.Length < 184) { TCP_AddWireless(RealData); } } } } } } |
都是通过结束标识来搞的
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
2018-12-21 处理SQL Server中的重复行