networking - Scapy 原始数据操作

标签 networking python-2.7 packet-sniffers scapy

我在处理原始数据时遇到问题。我正在尝试改变 resp_cookie 在我的 ISAKMP header 中,当我对数据包进行嗅探时,它都是 Raw Load='\x00\x43\x01.......... ' 下的原始数据格式> 大约有 3 行这样的内容。当我执行 Wireshark 捕获时,我看到了我想要更改的信息,但我似乎无法找到一种方法来转换和更改原始数据以查找和替换我正在寻找的信息。此外,当我执行 hexdump() 时,我可以看到我需要的信息,但我无法将其存储在变量中。当我键入 i = hexdump(pkt) 时,它会吐出 hexdump 但不会将 hexdump 存储在 i 中。

最佳答案

所以这篇文章有点旧,但我已经遇到了十几次,试图找到我遇到的类似问题的答案。我怀疑 OP 是否需要答案了,但如果其他人想做类似的事情......给你!

我在 google 的某个地方找到了以下代码片段,它适用于我的情况。

Scapy的Hexdump()、show()等方法只是将数据包输出到终端/控制台;它们实际上并不返回字符串或任何其他类型的对象。因此,您需要一种方法来拦截它打算写入的数据并将其放入一个变量中进行操作。

注意:这是 PYTHON 3.X 和 SCAPY 3K

import io
import scapy

#generic scapy sniff
sniff(iface=interface,prn=parsePacket, filter=filter)

使用上述嗅探方法,您将要执行以下操作。

def parsePacket(packet):

    outputPacket = '' 

    #setup
    qsave = sys.stdout
    q = io.StringIO() 

    #CAPTURES OUTPUT
    sys.stdout = q  

    #Text you're capturing
    packet.show()

    #restore original stdout
    sys.stdout = qsave

    #release output
    sout = q.getvalue()

    #Add to string (format if need be)
    outputPacket += sout + '\n'

    #Close IOStream
    q.close() 

    #return your packet
    return outputPacket

您返回的字符串 (outputPacket) 现在可以按照您想要的方式进行操作。

用您认为合适的任何函数替换 .show()。

附言如果从 Pythonic 的角度来看这有点粗糙,请原谅我……无论如何都不是 Python 开发人员。

关于networking - Scapy 原始数据操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18705953/

相关文章:

c - 尝试连接到Linux上未使用的端口

c - 通过 IP 地址控制设备有哪些方法?

android - 如何在 Genymotion/Android 模拟器上嗅探非 http 流量(套接字)?

Python 在特定条件下停止嗅探

networking - 读写 UDP 连接的套接字?

Ubuntu:无法使用 NAT 连接到主机的互联网连接

python-2.7 - 为什么我会收到 egg_info 错误?

python - 找不到目录时停止python程序关闭

python - 类型错误 : It would appear that nargs is set to conflict with the composite type arity

Python - scapy 数据包大小差异