怎么在python中使用scapy庫實現(xiàn)網卡收發(fā)包?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
問題:
測試時 收發(fā)流采用TestCenter、SmartBit等儀表來進行。如果仍采用其進行自動化冒煙,則會帶來效率低、成本高的問題。
解決方案:
采用網卡來收發(fā)流,雖然有性能統(tǒng)計上的缺陷,但可以驗證一些基本功能,且經濟。
采用scapy模塊,
1-獲取計算機網卡的iface,并預先設計好用哪些iface進行收發(fā)流;
2-conf.L2listen對各個iface進行監(jiān)聽
3-subprocess.Popen來調用tShark.exe啟動抓包,也可以調用ping.exe構造ping包
4-sendp發(fā)送二層報文,send發(fā)送三層報文
5-sniff嗅探iface上的指定報文,可以有過濾條件
6-停止wireshark抓包
7-close關閉對iface的監(jiān)聽
討論:
沒有嘗試采用sr1、srp來進行收發(fā)包。
整個過程相對比較清晰,而且步驟是成對出現(xiàn),方便記憶。
sniff嗅探時,會丟掉iface前面出現(xiàn)的部分報文,這個問題可能是沒有執(zhí)行好監(jiān)聽和啟動抓包導致。
沒有對網卡的具體性能標準作出說明,可能需要摸著石頭過河,如果發(fā)現(xiàn)網卡有不合適測試的,需要立即切換到儀表來測試。
#! usr/bin/env python # -*- coding:utf-8 -*- import os import sys import re import struct import string from scapy.all import * import subprocess conf.use_pcap = True ''' cmd python from scapy.all import * ls(Ether()) ls(IP()) ls(ICMP()) send(IP(dst='1.2.3.4')/ICMP()) sendp(Raw("zhongxing"), iface='eth25', loop=1, inter=0.2, verbose=False) 設置 inter 參數(shù)來設置發(fā)送相鄰兩個包直接的時間間隔 設置 timeout 參數(shù)來設置等待應答的超時時間 設置 retry 參數(shù)來設置重試次數(shù)。 ''' print u"實現(xiàn)網卡發(fā)包" target = [] for i in range(1,len(sys.argv)): m = sys.argv[i].split('=') if m[0]=='-t': target.append(m[1]) if m[0]=='-ip': target.append(m[1]) if m[0]=='-mac': target.append(m[1]) print 'test -- ',target print print u'獲取網卡的iface' eth_local = [] a = repr(conf.route).split('\n') for x in a: b = [] b = x.split(' ') for y in b: if re.search('eth', y): eth_local.append(y) print u'去重復' c = [] c.append(eth_local[0]) for i in range(0,len(eth_local),1): m = 0 for j in range(0,len(c),1): if c[j] == eth_local[i]: m += 1 if m==0: c.append(eth_local[i]) print c #['eth25', 'eth31', 'eth27'] print u'創(chuàng)建二層報文' src_mac = '00:00:11:11:22:22' dst_mac = '00:00:22:22:11:11' dst_ip = '1.2.3.4' src_ip = '5.6.7.8' src_port = 1234 dst_port = 5678 ##ls() ##ls(IP()) ##IP().show() ##lsc() pack_ip = IP(dst=dst_ip, src=src_ip, proto=1) ##ls(ICMP()) ##ls(UDP()) pack_icmp = ICMP(type=8) ##ls(Ether()) pack_ether = Ether(dst=dst_mac, src=src_mac, type=0x0800) info = Raw('zhongxing') t = str(pack_ether/pack_ip/pack_icmp/info) s = Ether(t) print u'待發(fā)送的報文為:',s.summary eth = c[1] print u'發(fā)送的網卡iface為 %s\n' % eth print u'---------開始監(jiān)聽 - 發(fā)送icmp - 嗅探icmp - 關閉監(jiān)聽----------' print u'---------開始監(jiān)聽-------------' L2socket = conf.L2listen listen_socket = L2socket(type=ETH_P_ALL, iface=eth) print listen_socket print conf.L2listen ####啟動抓包 ##cmd='C:\Program Files (x86)\Wireshark\tShark.exe' ##card_id = str(1) ##cap_file = str('H:\python\test.pcap') ##args = [cmd,"-i "+card_id,"-w",cap_file] ##print "*DEBUG*",args ##p=subprocess.Popen(args) print u'---------sendp()函數(shù)調用----------' sendp(s,iface=eth, verbose=False) ##print u'---------srp()函數(shù)調用----------' ##sr 函數(shù)是 Scapy 的核心,這個函數(shù)返回兩個列表, ##第一個列表是收到應答的包和其對應的應答, ##第二個列表是未收到應答的包, ##通常,我們需要調用別的函數(shù)來使得這兩個返回值更易于閱讀, ##help(srp) ##p = srp(s,iface=c[1], verbose=False) ##print p.show() print u'---------嗅探、過濾、保存pcap、讀取pcap----------' ##print sniff.__doc__ ##pkts = sniff(iface = 'eth25',filter = 'icmp',count = 3, prn=lambda x: x.summary()) ip = '172.10.0.1' subprocess.Popen(["ping.exe", ip]) #提供給sniff ##Ether / IP / ICMP 172.10.1.124 > 172.10.0.1 echo-request 0 / Raw ##Ether / IP / ICMP 172.10.0.1 > 172.10.1.124 echo-reply 0 / Raw ##Ether / IP / ICMP 172.10.1.124 > 172.10.0.1 echo-request 0 / Raw ##listen_socket1 = L2socket(listen_socket) ##pkts = sniff(iface = eth,filter = 'icmp',count = 20, timeout = 10, L2socket=listen_socket) pkts = sniff(iface = eth, filter = 'icmp', count = 20, timeout = 10) try: if 0 < len(pkts): print u'---------嗅探到報文----------' ##pkts[0].show() wrpcap('demo.pcap',pkts) read_pkts = rdpcap('demo.pcap') print read_pkts[0] print u'---------------輸出base64編碼格式的數(shù)據---------------' export_object(str(pkts[0])) print u'---------------轉換為base64編碼格式的數(shù)據---------------' newPkt = import_object('eNprYAqN+Q8GGp/TOCfN5GBwZWDwc/nCwNAgOItrDRdjLxD/Z+gEQitpgwvijAIMjAxgoODmAYLO\ /m7ebq6ubs7+ri6uAa5+YNrf2dHREaiEgbGQUQ8AnjEcMQ==') print newPkt s = Ether(newPkt) print u'待發(fā)送的報文為:',s.summary sendp(s,iface=eth, verbose=False) else: print u'---------沒有嗅探到報文----------' except: pass finally: print u'---------關閉監(jiān)聽-------------' listen_socket.close()
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。
分享標題:怎么在python中使用scapy庫實現(xiàn)網卡收發(fā)包-創(chuàng)新互聯(lián)
當前鏈接:http://chinadenli.net/article6/deddig.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供面包屑導航、Google、品牌網站設計、外貿網站建設、手機網站建設、軟件開發(fā)
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)