发布时间:2025-12-09 18:53:25 浏览次数:4
专业的构造和发送网络数据包的开发工具包,是个高层次的API函数库,允许开发者自己构造和发送网络数据包。
头文件:#include<libnet.h>
编译加:-lnet
①隐藏了很多底层细节,省去了很多麻烦:如缓冲区管理、字节流顺序、校验和计算等问题,使开发者把重心放到程序的开发中。
②可以轻松、快捷的构造任何形式的网络数据包,从而开发各种各样的网络程序。
③使用非常广泛,例子著名的软件Ettercap、Firewalk、Snort、Tcpreplay等。
④在1998年就出现了,但那时候还有很多缺陷,比如计算校验和非常繁琐等;
⑤Schiffman对其进行了完善,而且功能更加强大。至此,可以谁Libnet开发包非常完美了,使用人数越来越多。
利用libnet函数库开发应用程序的基本步骤
①数据包内存初始化
②构造数据包
③发送数据
④释放资源
libnet库主要功能
①内存管理
②地址解析
③包处理
①初始化
libnet_t *libnet_init(int injection_type, char *device, char *err_buf);功能:数据包内存初始化及环境建立参数:injection_type:构造的类型(LIBNET_LINK,LIBNET_TAW4, LIBNET_LINK_ADV(推荐), LIBNET_RAW4_ADV)device:网络接口,如"eth0"或IP地址,亦可为NULL(自动查询搜索)err_buf:存放出错的信息返回值:成功返回一个libnet句柄,失败返回NULL libnet_ptag_t libnet_build_udp(u_int16_t sp, u_int16_t dp,u_int16_t len, u_int16_t sum,u_int8_t *payload, u_int32_t payload_s,libnet_t *l, libnet_ptag_t ptag);功能:构造UDP数据包参数:sp:源端口号dp:目的端口号len:UDP包总长度sum:校验和,设为0,libnet自动填充payload:负载,可设置为NULLpayload_s:负载长度,或为0l:libnet句柄ptag:协议标记返回值:成功返回协议标记;失败返回-1构建IPv4数据包
libnet_ptag_t libnet_build_ipv4(u_int16_t ip_len, u_int8_t tos,u_int16_t id, u_int16_t flag,u_int8_t ttl, u_int8_t port,u_int16_t sum, u_int32_t src,u_int32_t dst, u_int8_t *payload,u_int32_t payload_s, libnet_t *l,libnet_ptag_t ptag);功能:构造一个IPv4数据包参数:ip_len:ip包总长tos:服务类型id:id表示flag:片偏移ttl:生存时间prot:上层协议sum:校验和,设为0,libnet自动填充src:源IP地址dst:目的IP地址payload:负载,可设置为NULLpayload_s:负载长度,或为0,l:libnet句柄ptag:协议标记返回值:成功返回协议标记;失败返回-1构建以太网数据包
libnet_ptag_t libnet_build_ethernet(u_int8_t *dst, u_int8_t *src,u_int16_t type, u_int8_t *payload,u_int32_t payload_s, libnet_t *l,libnet_ptag_t ptag);功能:构造一个以太网数据包参数:dst:目的macsrc:源mactype:上层协议类型payload:负载,即附带的数据payload_s:负载长度l:libnet句柄ptag:协议标记返回值:成功返回协议标记;失败返回-1③发送帧数据
int libnet_write(libnet_t *l);功能:发送数据到网络参数:l:libnet句柄返回值:失败返回-1,成功返回其他。④释放资源
void libnet_destroy(libnet_t *l);功能:释放资源参数:l:libnet句柄返回值:无