gpt4 book ai didi

python - 从 Python 和 impacket 获取 TCP 数据包有效载荷

转载 作者:太空宇宙 更新时间:2023-11-03 11:35:13 24 4
gpt4 key购买 nike

我已经能够使用基于此示例的代码找到感兴趣的数据包:

How can I filter a pcap file by specific protocol using python?

TCP 数据包的下一个 child 是实际数据:

   if isinstance(child1, TCP):
if child1.get_th_dport() == 80:
x = child1.child()
print x

这会像 wire shark 一样打印出数据包数据,并显示十六进制和 ascii 版本。但是到目前为止,我一直无法找到一种方法来简单地获取十六进制内容。我知道我可以操纵可打印的输出,但我认为必须有一种方法可以获取十六进制形式的数据...

我查看了样本,但似乎没有人这样做。有人知道正确的方法吗?

最佳答案

您可以使用 packet.get_data_as_string() 获取原始字节,然后根据需要显示它。我复制了 print child 生成的“十六进制列”输出。也应该很容易调整以生成 ASCII 列:

def display_hex(pkt, cols=8):
size = cols * 4
data = ''.join('%02x' % ord(b) for b in pkt.get_data_as_string())
for i in range(0, len(data), size):
for j in range(0, size, 4):
print data[i+j:i+j+4],
print

if isinstance(child, TCP):
display_hex(child)

输出:

1703 0103 b0b1 9387 be4e fe00 9230 6192
e3bb 217e c1cb 8511 556f f986 4f31 542d
15c6 f42e f3bb 93d5 cf33 f126 c174 dbc4
... snip ...
8b1d 8707 96d6 7a18 2aab fd0b 48ee c4eb
b7d8 a67f 8bc0 597d 1044 a076 1a9e 24ba
959b fda3 1adb 2384 669c e6c8 c3b5 bef4
1189 eda8 3e

关于python - 从 Python 和 impacket 获取 TCP 数据包有效载荷,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5864632/

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