TCP协议传输中的粘包和拆包

一 TCP协议的粘包和拆包说明

经常用tcp协议开发上位机或下位机的同事都会或多或少遇到粘包和拆包的问题,这是在网络通信中最常见的两个问题,这也与数据的发送和接收方式有关。

1 TCP粘包

指的是发送方发送的多个小数据包被接收方一次性接收的情况。这可能是因为发送方发送数据的速度过快,接收方无法及时处理,从而多个数据包被合并成一个大的数据包一起接收。

2 TCP拆包

指发送方发送的一个大数据包被接收方拆分成多个小的数据包接收的情况。这可能是由于网络中的路由器、交换机等设备的限制,导致大的数据包在传输过程中被分割成多个小的数据包。接收方需要能够正确地组装这些小数据包以还原原始的大数据包。

二 粘包与拆包造成的原因

粘包与拆包造成的原因是因为TCP是面向流的协议,数据是一连串的字节流,而不是消息边界明确的数据包

三 解决粘包

1 定长消息:

在每个消息之前添加消息长度的信息,接收方根据长度信息判断消息的边界。

java代码示例:

java 复制代码
// 发送端
int messageLength = 8; // 消息长度
String message = "68123456";
String formattedMessage = String.format("%-" + messageLength + "s", message);
outputStream.write(formattedMessage.getBytes());

// 接收端
byte[] buffer = new byte[messageLength];
int bytesRead = inputStream.read(buffer);
String receivedMessage = new String(buffer, 0, bytesRead);

2 分隔符:

使用特定的分隔符(如换行符或其他特殊字符)来标志消息的结束。

java代码示例:

java 复制代码
// 发送端
String message = "68123456\n";
outputStream.write(message.getBytes());

// 接收端
BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream));
String receivedMessage = reader.readLine();

3 消息头部包含长度信息:

在消息头部添加长度字段,表示后续消息的长度。

java 复制代码
// 发送端
String message = "68123456";
int messageLength = message.length();
outputStream.writeInt(messageLength);
outputStream.write(message.getBytes());

// 接收端
int receivedLength = inputStream.readInt();
byte[] buffer = new byte[receivedLength];
int bytesRead = inputStream.read(buffer);
String receivedMessage = new String(buffer, 0, bytesRead);

4 正则匹配:

使用正则表达式处理(不推荐),接入设备不同品牌可能存在上传的数据不是很标准的情况下可以使用完善处理,兼容报文数据格式。

java 复制代码
      // 模拟接收到的数据
        String receivedData = "68123456PP68123456PP68123456";

        // 定义正则表达式,假设消息之间使用 "PP" 作为分隔符
        String regex = "PP";
        Pattern pattern = Pattern.compile(regex);
        Matcher matcher = pattern.matcher(receivedData);

        // 使用正则表达式切分消息
        while (matcher.find()) {
            String message = receivedData.substring(matcher.start(), matcher.end());
            System.out.println("Received message: " + message);
        }
相关推荐
孙克旭_7 分钟前
day051-ansible循环、判断与jinja2模板
linux·运维·服务器·网络·ansible
悟空胆好小1 小时前
分音塔科技(BABEL Technology) 的公司背景、股权构成、产品类型及技术能力的全方位解读
网络·人工智能·科技·嵌入式硬件
DoraBigHead1 小时前
《电磁波的浪漫,铜线上的灵魂》——计算机网络·物理层全解版
网络协议
ssswywywht2 小时前
OSPF实验
网络
FCM662 小时前
HCIA第一次实验报告:静态路由综合实验
网络·tcp/ip·信息与通信
apihz3 小时前
VM虚拟机全版本网盘+免费本地网络穿透端口映射实时同步动态家庭IP教程
android·服务器·开发语言·网络·数据库·网络协议·tcp/ip
dog2503 小时前
TCP 传输时 sk_buff 的 clone 和 unclone
网络·网络协议·tcp/ip
学习溢出4 小时前
【网络安全】理解安全事件的“三分法”流程:应对警报的第一道防线
网络·安全·web安全·网络安全·ids
智慧化智能化数字化方案5 小时前
华为IPD(集成产品开发)流程是其研发管理的核心体系
网络·华为ipd流程·ipd流程体系·ipd产品研发
kfepiza5 小时前
Linux的NetworkManager的nmcli配置网桥(bridge) 笔记250712
linux·运维·网络·笔记·tcp/ip·ip·tcp