gpt4 book ai didi

python - python3中的数据包嗅探器

转载 作者:行者123 更新时间:2023-11-28 16:35:33 26 4
gpt4 key购买 nike

所以浏览网页,有很多关于数据包嗅探器的资料。然而,所有的代码或库似乎只适用于 python2。我正在尝试在 python3 中制作一个简单的数据包嗅探器以进行测试。

我从 http://www.binarytides.com/python-packet-sniffer-code-linux/ 中获取了代码并尝试将其转换为 python3。但是python2和python3处理struct.unpack函数的方式有问题。

这是他们的代码片段(针对 python3 稍作修改),它获取以太网 header 并打印出 MAC 地址。

def eth_addr (a) :
a = str(a) # added because TypeError occurs with ord() without it
b = "%.2x:%.2x:%.2x:%.2x:%.2x:%.2x" % (ord(a[0]) , ord(a[1]) , ord(a[2]), ord(a[3]), ord(a[4]) , ord(a[5]))
return b

#create a AF_PACKET type raw socket (thats basically packet level)
#define ETH_P_ALL 0x0003 /* Every packet (be careful!!!) */
try:
s = socket.socket( socket.AF_PACKET , socket.SOCK_RAW , socket.ntohs(0x0003))
except socket.error as msg:
msg = list(msg)
print('Socket could not be created. Error Code : ' + str(msg[0]) + ' Message ' + msg[1])
sys.exit()

# receive a packet
while True:
packet = s.recvfrom(65565)

#packet string from tuple
packet = packet[0]

#parse ethernet header
eth_length = 14

eth_header = packet[:eth_length]
eth = unpack('!6s6sH' , eth_header)
eth_protocol = socket.ntohs(eth[2])
print('Destination MAC : ' + eth_addr(packet[0:6]) + ' Source MAC : ' + eth_addr(packet[6:12]) + ' Protocol : ' + str(eth_protocol))

插入打印语句揭示了头文件的解包,python2和python3似乎有区别。 Python3 仍然将数据编码为二进制数据。但是,如果我尝试对数据进行解码,它会抛出有关不正确的“utf-8”格式的错误。

如何让 MAC 地址在 python3 中正确格式化?

谢谢

最佳答案

删除 a = str(a) 行和 ord() 调用:

def eth_addr (a) :
b = "%.2x:%.2x:%.2x:%.2x:%.2x:%.2x" % (a[0] , a[1] , a[2], a[3], a[4] , a[5])
return b

在 Python 3 中,bytes 对象在下标时生成整数,因此您不需要对它们调用 ord()。像这样将 bytes 对象转换为 str() 是不正确的,因为它会尝试将其解析为 UTF-8。这是不成功的,因为你没有 UTF-8,你有随机二进制垃圾。

关于python - python3中的数据包嗅探器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26874344/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com