您好,登錄后才能下訂單哦!
怎么在python中使用scapy庫實現網卡收發包?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
問題:
測試時 收發流采用TestCenter、SmartBit等儀表來進行。如果仍采用其進行自動化冒煙,則會帶來效率低、成本高的問題。
解決方案:
采用網卡來收發流,雖然有性能統計上的缺陷,但可以驗證一些基本功能,且經濟。
采用scapy模塊,
1-獲取計算機網卡的iface,并預先設計好用哪些iface進行收發流;
2-conf.L2listen對各個iface進行監聽
3-subprocess.Popen來調用tShark.exe啟動抓包,也可以調用ping.exe構造ping包
4-sendp發送二層報文,send發送三層報文
5-sniff嗅探iface上的指定報文,可以有過濾條件
6-停止wireshark抓包
7-close關閉對iface的監聽
討論:
沒有嘗試采用sr1、srp來進行收發包。
整個過程相對比較清晰,而且步驟是成對出現,方便記憶。
sniff嗅探時,會丟掉iface前面出現的部分報文,這個問題可能是沒有執行好監聽和啟動抓包導致。
沒有對網卡的具體性能標準作出說明,可能需要摸著石頭過河,如果發現網卡有不合適測試的,需要立即切換到儀表來測試。
#! 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 參數來設置發送相鄰兩個包直接的時間間隔 設置 timeout 參數來設置等待應答的超時時間 設置 retry 參數來設置重試次數。 ''' print u"實現網卡發包" 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'創建二層報文' 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'待發送的報文為:',s.summary eth = c[1] print u'發送的網卡iface為 %s\n' % eth print u'---------開始監聽 - 發送icmp - 嗅探icmp - 關閉監聽----------' print u'---------開始監聽-------------' 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()函數調用----------' sendp(s,iface=eth, verbose=False) ##print u'---------srp()函數調用----------' ##sr 函數是 Scapy 的核心,這個函數返回兩個列表, ##第一個列表是收到應答的包和其對應的應答, ##第二個列表是未收到應答的包, ##通常,我們需要調用別的函數來使得這兩個返回值更易于閱讀, ##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編碼格式的數據---------------' export_object(str(pkts[0])) print u'---------------轉換為base64編碼格式的數據---------------' newPkt = import_object('eNprYAqN+Q8GGp/TOCfN5GBwZWDwc/nCwNAgOItrDRdjLxD/Z+gEQitpgwvijAIMjAxgoODmAYLO\ /m7ebq6ubs7+ri6uAa5+YNrf2dHREaiEgbGQUQ8AnjEcMQ==') print newPkt s = Ether(newPkt) print u'待發送的報文為:',s.summary sendp(s,iface=eth, verbose=False) else: print u'---------沒有嗅探到報文----------' except: pass finally: print u'---------關閉監聽-------------' listen_socket.close()
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。