from scapy.all import *
import threading
二、实现ip扫描
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扫描功能的文章就介绍到这了,更多相关Python scapy实现arp扫描内容请搜索软件开发网以前的文章或继续浏览下面的相关文章希望大家以后多多支持软件开发网!
您可能感兴趣的文章:python使用scapy模块实现ARP扫描的过程利用Python库Scapy解析pcap文件的方法python 的 scapy库,实现网卡收发包的例子Python Scapy随心所欲研究TCP协议栈Python中使用scapy模拟数据包实现arp攻击、dns放大攻击例子python通过scapy获取局域网所有主机mac地址示例python使用scapy模块实现ping扫描的过程详解