日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Linux下PF_PACKET的使用

系統 4942 0

sock_raw(注意一定要在root下使用)原始套接字編程可以接收到本機網卡上的數據幀或者數據包,對于監聽網絡的流量和分析是很有作用的.一共可以有3種方式創建這種socket
?
1.socket(AF_INET, SOCK_RAW, IPPROTO_TCP|IPPROTO_UDP|IPPROTO_ICMP)發送接收ip數據包,不能用IPPROTO_IP,因為如果是用了IPPROTO_IP,系統根本就不知道該用什么協議。
2.socket(PF_PACKET, SOCK_RAW, htons(ETH_P_IP|ETH_P_ARP|ETH_P_ALL))發送接收以太網數據幀
3.socket(AF_INET, SOCK_PACKET, htons(ETH_P_IP|ETH_P_ARP|ETH_P_ALL))過時了,不要用啊
?
?

1.介紹
在linux中提供了PF_PACKET接口可以操作鏈路層的數據。
?
2.使用方法
定義一個pf_packet = socket(PF_SOCKET, SOCK_RAW, htons(ETH_P_RARP));
就可以利用函數sendto和recefrom來讀取和發送鏈路層的數據包了(當然,發送ARP包,上面第三個參數要變為 htons(ETH_P_ARP),或者IP的包為ETH_P_IP,可查看文件/usr/include/linux/if_ether.h文件看到所有支持的協議)。
?
3.在使用SOCK_RAW, SOCK_DGRAM和SOCK_PACKET的區別
在socket的第一個參數使用PF_PACKET的時候,上述三種socket的類型都可以使用。但是有區別。
(1)使用SOCK_RAW發送的數據必須包含鏈路層的協議頭,接受得到的數據包,包含鏈路層協議頭。而使用SOCK_DGRAM則都不含鏈路層的協議頭。
(2)SOCK_PACKET也是可以使用的,但是已經廢棄,以后不保證還能支持,不推薦使用。
(3)在使用SOCK_RAW或SOCK_DGRAM和SOCK_PACKET時,在sendto和recvfrom中使用的地址類型不同,前兩者使用sockaddr_ll類型的地址,而后者使用sockaddr類型的地址。
(4)如socket的第一個參數使用PF_INET,第二個參數使用SOCK_RAW,則可以得到原始的IP包。

Linux下PF_PACKET的使用


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 电白县| 开封县| 资阳市| 江安县| 天台县| 化州市| 辽中县| 泰安市| 高安市| 泰宁县| 中方县| 上蔡县| 遵义市| 金湖县| 泽普县| 聂拉木县| 佛教| 陕西省| 佛山市| 吴忠市| 农安县| 榆社县| 郴州市| 孙吴县| 温宿县| 内黄县| 遂平县| 清流县| 亳州市| 江门市| 盐边县| 正蓝旗| 招远市| 云南省| 定日县| 洮南市| 嘉义市| 民勤县| 岳普湖县| 娄底市| 锡林郭勒盟|