linux sock_raw原始套接字编程

linux sock_raw原始套接字编程

ID:41037273

大小:21.52 KB

页数:11页

时间:2019-08-14

linux sock_raw原始套接字编程_第1页
linux sock_raw原始套接字编程_第2页
linux sock_raw原始套接字编程_第3页
linux sock_raw原始套接字编程_第4页
linux sock_raw原始套接字编程_第5页
资源描述:

《linux sock_raw原始套接字编程》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、linuxsock_raw原始套接字编程sock_raw原始套接字编程可以接收到本机网卡上的数据帧或者数据包,对与监听网络的流量和分析是很有作用的.一共可以有3种方式创建这种socket1.socket(AF_INET,SOCK_RAW,IPPROTO_TCP

2、IPPROTO_UDP

3、IPPROTO_ICMP)发送接收ip数据包2.socket(PF_PACKET,SOCK_RAW,htons(ETH_P_IP

4、ETH_P_ARP

5、ETH_P_ALL))发送接收以太网数据帧3.socket(AF_INET,SOCK_PACKET,htons(ETH_P_IP

6、ETH_P_ARP

7、ETH_P_A

8、LL))过时了,不要用啊理解一下SOCK_RAW的原理,比如网卡收到了一个14+20+8+100+4的udp的以太网数据帧.首先,网卡对该数据帧进行硬过滤(根据网卡的模式不同会有不同的动作,如果设置了promisc混杂模式的话,则不做任何过滤直接交给下一层输入例程,否则非本机mac或者广播mac会被直接丢弃).按照上面的例子,如果成功的话,会进入ip输入例程.但是在进入ip输入例程之前,系统会检查系统中是否有通过socket(AF_PACKET,SOCK_RAW,..)创建的套接字.如果有的话并且协议相符,在这个例子中就是需要ETH_P_IP或者ETH_P_ALL类型.系统就给每个这样的soc

9、ket接收缓冲区发送一个数据帧拷贝.然后进入下一步.其次,进入了ip输入例程(ip层会对该数据包进行软过滤,就是检查校验或者丢弃非本机ip或者广播ip的数据包等,具体要参考源代码),例子中就是如果成功的话会进入udp输入例程.但是在交给udp输入例程之前,系统会检查系统中是否有通过socket(AF_INET,SOCK_RAW,..)创建的套接字.如果有的话并且协议相符,在这个例子中就是需要IPPROTO_UDP类型.系统就给每个这样的socket接收缓冲区发送一个数据帧拷贝.然后进入下一步.最后,进入udp输入例程...ps:如果校验和出错的话,内核会直接丢弃该数据包的.而不会拷贝给sock

10、_raw的套接字,因为校验和都出错了,数据肯定有问题的包括所有信息都没有意义了.进一步分析他们的能力.1.socket(AF_INET,SOCK_RAW,IPPROTO_UDP);能:该套接字可以接收协议类型为(tcpudpicmp等)发往本机的ip数据包,从上面看的就是20+8+100.不能:不能收到非发往本地ip的数据包(ip软过滤会丢弃这些不是发往本机ip的数据包).不能:不能收到从本机发送出去的数据包.发送的话需要自己组织tcpudpicmp等头部.可以setsockopt来自己包装ip头部这种套接字用来写个ping程序比较适合2.socket(PF_PACKET,SOCK_RAW,h

11、tons(x));这个套接字比较强大,创建这种套接字可以监听网卡上的所有数据帧.从上面看就是20+20+8+100.最后一个以太网crc从来都不算进来的,因为内核已经判断过了,对程序来说没有任何意义了.能:接收发往本地mac的数据帧能:接收从本机发送出去的数据帧(第3个参数需要设置为ETH_P_ALL)能:接收非发往本地mac的数据帧(网卡需要设置为promisc混杂模式)协议类型一共有四个ETH_P_IP0x800只接收发往本机mac的ip类型的数据帧ETH_P_ARP0x806只接受发往本机mac的arp类型的数据帧ETH_P_ARP0x8035只接受发往本机mac的rarp类型的数据帧E

12、TH_P_ALL0x3接收发往本机mac的所有类型iparprarp的数据帧,接收从本机发出的所有类型的数据帧.(混杂模式打开的情况下,会接收到非发往本地mac的数据帧)发送的时候需要自己组织整个以太网数据帧.所有相关的地址使用structsockaddr_ll而不是structsockaddr_in(因为协议簇是PF_PACKET不是AF_INET了),比如发送给某个机器,对方的地址需要使用structsockaddr_ll.这种socket大小通吃,强悍下面是一段相关的代码:...intsockfd=socket(PF_PACKET,SOCK_RAW,htons(ETH_P_ALL));s

13、tructsockaddr_llsll;memset(&sll,0,sizeof(sll));sll.sll_family=AF_PACKET;structifreqifstruct;strcpy(ifstruct.ifr_name,"eth0");ioctl(sockfd,SIOCGIFINDEX,&ifstruct);sll.sll_ifindex=ifstruct.ifr_ifindex;s

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。