从sourceforge.net上下载的libnet-1.1.5,最后更新日期显示2010-11-09。
以前使用libnet发送IPV4的TCP/UDP数据是没问题的,测试IPV6时发生段错误,分析代码发现libnet_checksum.c文件中的libnet_inet_checksum函数处理IPV6时有两处小BUG:
BUG1:
207 if (iph_p->ip_v == 6)
208 {
is_ipv6 = 1;
209 ip6h_p = (struct libnet_ipv6_hdr *)iph_p;
需要设置is_ipv6标志,不然后面取IP地址时会当作IPV4处理。
BUG2:
279 sum += ntohs(iph_p->ip_p + h_len);
iph_p此处已是NULL,应改为:
279 sum += ntohs(IPPROTO_TCP + h_len);
libnet还是挺好用的,就是太久没更新了,估计某些地方当初没写完。(比如libnet_autobuild_ipv6就还没实现)
另外li

libnet-1.1.5在处理IPv6时存在两个错误:1. 在检查版本号时未正确设置is_ipv6标志,可能导致IPv6数据包被误处理为IPv4。2. 在计算校验和时尝试访问NULL指针iph_p,应修正为计算协议字段加上负载长度。此外,libnet_build_ipv6接口的参数使用可能引起混淆,尤其是payload和payload_s在发送TCP数据包时的使用情况。
最低0.47元/天 解锁文章
1722

被折叠的 条评论
为什么被折叠?



