免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3397 | 回复: 3
打印 上一主题 下一主题

[C++] TCP数据使用libpcap库抓取后,如何组包的问题 [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 10:01:44
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-02-27 09:42 |只看该作者 |倒序浏览
使用libpcap库抓取的tcp数据包,发送给处理程序,由于处理程序是多线程,重新组业务数据包的时候需要判断序号。
现在的想法是每次收到包判断是不是预期的序号,如果不是则放到一个队列中,继续收包,收到正确的包,也检查队列中是否存在需要的包。
问题是我并没有记录tcp连接状态的信息(程序开始抓包时,TCP连接可能已经建立,所以可能漏掉SYN,不好维护TCP连接状态),如果连接重连,序号发生改变,程序继续接收预期序号的包就会有问题,不知道有什么好的方法能够解决这个问题吗?

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 10:01:44
2 [报告]
发表于 2015-02-27 09:59 |只看该作者
现在的想法是: 第一包确定序号,收到小于期望序号的就丢掉,大于期望序号就存入一个缓存队列中,正确序号的就接收(然后扫描缓存队列中有午期望的序号)。 如果收到RST 或者 SYN, 就重新计算序号。
不知道会不会有问题。

论坛徽章:
3
天蝎座
日期:2014-10-25 13:44:312015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:48:31
3 [报告]
发表于 2015-02-27 15:57 |只看该作者
可以参考wireshark代码

PS:不用问我,我没看过

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 10:01:44
4 [报告]
发表于 2015-02-28 09:19 |只看该作者
wireshark 源码不会涉及到你业务包的重组,他不能知道你自定义的帧格式。
而且wireshark只是负责抓包,他貌似不负责排序吧,只是按抓取的先后时间。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP