您好,登錄后才能下訂單哦!
如何在Python3中利用scapy局域網實現一個自動多線程arp掃描功能?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
from scapy.all import * import threading
1.獲取c段ip地址
在ARP()里面有ip地址,我們可以從里面提取出前3段出來
ARP().show()
然后通過從后查找最后一個.得到最后一段位數,然后總長度-最后一段長度就能取出前3段
tip=ARP().psrc print(tip[:(len(tip)-tip[::-1].find('.'))])
2.arp掃描函數實現
然后就是建立函數實現掃描了,構造arp包->發送包->判斷是否響應->輸出信息
def ScanIp(ip): pkt=Ether(dst="ff:ff:ff:ff:ff:ff")/ARP(pdst=ip) res=srp1(pkt,timeout=10,verbose=0) if res: print(res.psrc) print(res.hwsrc)
然后來在加個判斷返回的ip跟我們要掃描的ip是否一致,然后加上異常處理
def ScanIp(ip): pkt=Ether(dst="ff:ff:ff:ff:ff:ff")/ARP(pdst=ip) try: res=srp1(pkt,timeout=10,verbose=0) if res.psrc==ip: print(res.psrc) print(res.hwsrc) except: pass
現在把輸出結果美化一下,不然直接print很難看
def ScanIp(ip): pkt=Ether(dst="ff:ff:ff:ff:ff:ff")/ARP(pdst=ip) try: res=srp1(pkt,timeout=10,verbose=0) if res.psrc==ip: print('IP MAC') print('[+]'+res.psrc+' '+res.hwsrc) except: pass
嘗試調用一下
ScanIp('192.168.123.1')
現在看起來就很舒服
3.多線程
現在我們只需要循環一下c段ip然后用多線程跑起來就行了
for i in range(1,256): ip=tip+str(i) Go=threading.Thread(target=ScanIp,args=(ip,)) Go.start()
然后看一下效果好像不是我們想要的因為IP MAC輸出了很多次看起來很難受
然后這里把輸出移動到函數外的for循環上方,然后判斷一下__name__,這樣就完成了所有的功能了
from scapy.all import * import threading tip=ARP().psrc tip=tip[:(len(tip)-tip[::-1].find('.'))] def ScanIp(ip): pkt=Ether(dst="ff:ff:ff:ff:ff:ff")/ARP(pdst=ip) try: res=srp1(pkt,timeout=10,verbose=0) if res.psrc==ip: print('[+]'+res.psrc+' '+res.hwsrc) except: pass if __name__=='__main__': print('IP MAC') for i in range(1,256): ip=tip+str(i) Go=threading.Thread(target=ScanIp,args=(ip,)) Go.start()
運行效果
看完上述內容,你們掌握如何在Python3中利用scapy局域網實現一個自動多線程arp掃描功能的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。