【ESP8266】ESP8266的TCP分包处理

前言

在阅读ESP8266_NONOS_SDK的IoT_Demo示例工程源码的时候,发现一段TCP分包的处理,特此张贴出来,写一篇学习笔记。

提醒

阅读本文最好有一定的ESP8266 SDK开发基础,至少要接触过ESP8266的TCP接口。

核心代码

下面来看下核心代码。

static void ICACHE_FLASH_ATTR
tcp_recv_cb(void *arg, char *pusrdata, unsigned short length)
{
    char *pstr = NULL;
    static char pbuffer[1024 * 2] = {0};
    struct espconn *pespconn = arg;

    if (length == 1460) {
        os_memcpy(pbuffer, pusrdata, length);
    } else {
        struct espconn *pespconn = (struct espconn *)arg;

        os_memcpy(pbuffer + os_strlen(pbuffer), pusrdata, length);

        if(pstr = (char *)os_strstr(pbuffer, "Hello") != NULL){
            // TODO:
        }
    }
}

定义各种变量后,就是一个if判断语句,判断数据包长度是否等于1460字节。为什么是1460呢?因为TCP的MSS默认就是1460。为什是1460呢,因为以太网的MTU值为1500字节,MSS再根据“MTU-40字节”这个公式算出来,因此1460字节。

什么是MSS和MTU?

MSS(Management Support System),最大报文段长度,是TCP协议定义的一个选项,用于在TCP连接建立时,收发双方协商通信时每一个报文段所能承载的最大数据长度。

MTU(Maximum Transmission Unit),意思是网络上传送的最大数据包,一般以太网的MTU值是1500字节。

如果收到的的数据包等于1460字节,则使用os_memcpy函数把该数据包拷贝到缓冲区pbufferpbuffer是一个局部静态的2KB的数组。

如果数据包长度不等于1460字节,则进入else流程。把后面的数据包在用os_memcpy函数拷贝到pbuffer缓冲区,第一个参数pbuffer + os_strlen(pbuffer),的os_strlen(pbuffer)是为了跳过前面数据的地址,免得后面的数据覆盖了前面的数据。

之后调用if(pstr = (char *)os_strstr(pbuffer, "Hello") != NULL)等判断语句查找相关字段。

不过该处理方法有明显的局限性,就是缓冲区只有2KB大小,最多只能缓冲两个TCP数据包。同时后面的判断语句也只是做了一个if (length == 1460) else,如果接收到第二个数据包也是1460字节,则覆盖掉第一个TCP数据包的缓冲数据内容。

因此该核心代码虽然可以处理TCP的分包,但是只能处理两个TCP分包,超过两个TCP分包就会出现BUG。

其他处理方法

我在之前的文章有过处理TCP粘包分包的方法——《TCP Socket的粘包和分包的处理》。

其实就是在第一个数据包里定义一个用户数据长度的字段,如果收到的数据包大小小于这个长度,则缓冲该数据包及继续接收后面的数据包。所有数据包接受完后,再进行处理。

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2022 / 01/ 30: 新版esptool 刷micropython固件指令不是 esptool.py cmd... 而是 esptool cmd... 即可;另外rshell 在 >= python 3.10 的时候出错解决方法可以查看:  已于2022年发布的: 第二章:修复rshell在python3.10出错 免费内容: https://edu.csdn.net/course/detail/29666 micropython语法和python3一样,编写起来非常方便。如果你快速入门单片机玩物联网而且像轻松实现各种功能,那绝力推荐使用micropython。方便易懂易学。 同时如果你懂C语音,也可以用C写好函数并编译进micropython固件里然后进入micropython调用(非必须)。 能通过WIFI联网(2.1章),也能通过sim卡使用2G/3G/4G/5G联网(4.5章)。 为实现语音控制,本教程会教大家使用tensorflow利用神经网络训练自己的语音模型并应用。为实现通过网页控制,本教程会教大家linux(debian10 nginx->uwsgi->python3->postgresql)网站前后台入门。为记录单片机传输过来的数据, 本教程会教大家入门数据库。  本教程会通过通俗易懂的比喻来讲解各种原理与思路,并手把手编写程序来实现各项功能。 本教程micropython版本是 2019年6月发布的1.11; 更多内容请看视频列表。  学习这门课程之前你需要至少掌握: 1: python3基础(变量, 循环, 函数, 常用库, 常用方法)。 本视频使用到的零件与淘宝上大致价格:     1: 超声波传感器(3)     2: MAX9814麦克风放大模块(8)     3: DHT22(15)     4: LED(0.1)     5: 8路5V低电平触发继电器(12)     6: HX1838红外接收模块(2)     7:红外发射管(0.1),HX1838红外接收板(1)     other: 电表, 排线, 面包板(2)*2,ESP32(28)  

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值