区块链网站开发郑州做网站推广价格
news/
2025/9/27 13:31:33/
文章来源:
区块链网站开发,郑州做网站推广价格,深圳办公室装修多少钱一个平方,中国互联网发展报告2023本文主要来自于linux自带的man packet手冊#xff1a; http://man7.org/linux/man-pages/man7/packet.7.html 平时常常使用的INET套接字提供的是7层的抓包能力#xff0c;抓上来的data直接就是tcp或者udp的payload#xff0c;无需关心L3和L4的头部信息。 Packet套接字提供的… 本文主要来自于linux自带的man packet手冊 http://man7.org/linux/man-pages/man7/packet.7.html 平时常常使用的INET套接字提供的是7层的抓包能力抓上来的data直接就是tcp或者udp的payload无需关心L3和L4的头部信息。 Packet套接字提供的是L2的抓包能力也叫raw socket意思就是不经过操作系统tcp/ip协议栈处理的packet抓上来的包须要自己处理tcp/ip的头部信息。 眼下使用packet套接字的主要有libpcapnetsniff-nghostapdhostapd是一个用户层的无线AP管理程序。 linux提供了的packet 套接字函数API例如以下 #include sys/socket.h#include netpacket/packet.h#include net/ethernet.h /* the L2 protocols */packet_socket socket(AF_PACKET, int socket_type, int protocol); socket_type有SOCK_RAW 和 SOCK_DGRAM这两个的主要差别是2层的头部处理。 假设指定SOCK_RAW, 那么我们得到的数据包括全部的L2 header和payload 假设指定SOCK_DGRAM, 那么我们收到的数据会去掉L2的header是IP header和payload。 二层的头部信息会放到一个通用的struct sockaddr_ll结构体中。 protocol主要是linux/if_ether.h中定义的协议类型我们能够指定ETH_P_IP来抓取IP packetETH_P_ARP 来抓取ARP的packet普通情况下我们能够指定ETH_P_ALL来抓取全部类 型的packet。 注意传入參数的时候应该转化成网络字节序htons(ETH_P_ALL)。 sockaddr_ll结构体用来表似乎一个设备独立的物理层地址信息定义例如以下 struct sockaddr_ll {unsigned short sll_family; /* Always AF_PACKET */unsigned short sll_protocol; /* Physical layer protocol */int sll_ifindex; /* Interface number */unsigned short sll_hatype; /* ARP hardware type */unsigned char sll_pkttype; /* Packet type */unsigned char sll_halen; /* Length of address */unsigned char sll_addr[8]; /* Physical layer address */};每一个域的定义例如以下 sll_family: 总是AF_PACKET ssll_protocol: linux/if_ether.h中定义的那些协议类型也就是我们传给socket的第二个參 数注意是网络序。 sll_ifindex: 内核中网卡的index定义在ifreq结构体中能够參考以下的链接 http://man7.org/linux/man-pages/man7/netdevice.7.html if_nametoindex()函数提供了从网卡名到index的转换后面的演示样例代码中会用到这个函数。如 果man找不到这个函数使用方法那么须要安装 manpages-posix-dev 。 sll_hatype: ARP硬件类型在头文件linux/if_arp.h中定义比方ARPHRD_ETHER表示 10Mbps 的Ethernet网卡类型。内核使用ARPHDR_XXX来表示网卡类型。 sll_pkttype: 表示当前接收的数据包的类型主要有以下几种合法的值 PACKET_HOST 发送给当前主机的包,PACKET_BROADCAST 广播数据包,PACKET_MULTICAST 多播数据包PACKET_OTHERHOST 因为网卡设置了混杂模式收到的发送给别的主机的包PACKET_OUTGOING 从本机发出的不小心loopback到当前socket了这些类型仅仅有接收的时候才有意义。 sll_halen: 表示当前mac地址的长度 sll_addr: 存储当前的mac地址 发送数据包的时候仅仅要设置以下几个域就足够了 sll_family, sll_addr, sll_halen, sll_ifindex. 其余的都应该设置为0 sll_hatype 和 sll_pkttype在接收数据包的时候会被设置为当前数据包的信息。 对于bind()函数来说仅仅有sll_protocol 和 sll_ifindex会被用到。 本文兴许系列packet socket 选项以及mmap相关都在个人的独立blog上 www.hiyoufu.com 欢迎訪问 转载于:https://www.cnblogs.com/mfrbuaa/p/4480380.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/919513.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!