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);
                          }
                      }
                  }
              }
          }
      }

  都是通过结束标识来搞的

posted @   ZaraNet  阅读(168)  评论(0编辑  收藏  举报
编辑推荐:
· 从 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中的重复行
点击右上角即可分享
微信分享提示