我在尝试使用 Scappy 生成原始数据包时遇到了一个奇怪的问题。
我正在执行以下操作:
eee=Ether(dst='08:00:11:11:11', src='08:00:11:11:22:22', type=0x888)/Raw(load='112233445566778888776655443322110901')
但是当我对新创建的数据包进行十六进制转储时:
hexdump(eee)
0000 08 00 11 11 11 00 08 00 11 11 22 22 08 88 **31 31** ..........""..11
0010 **32 32** 33 33 34 34 35 35 36 36 37 37 38 38 38 38 2233445566778888
0020 37 37 36 36 35 35 34 34 33 33 32 32 31 31 30 39 7766554433221109
0030 30 31
看起来它正在将 3 附加到有效负载的十六进制转储版本。我真的不知道那 3 是从哪里出现的。
提前感谢您的任何提示。
Raw
层采用load
参数的二进制表示形式。由于字符1
的 ascii 值是0x31
的,而字符2
的 ascii 值是0x32
的,字符串1122
的二进制表示形式是0x31313232
的。这就是您所看到的hexdump
输出。
您需要做的是在将字符串作为load
参数传输到Raw
层之前对其进行解码:
In [1]: from scapy.all import *
WARNING: No route found for IPv6 destination :: (no default route?)
In [2]: eee=Ether(dst='08:00:11:11:11', src='08:00:11:11:22:22', type=0x888)/Raw(load='112233445566778888776655443322110901'.decode("HEX"))
In [3]: hexdump(eee)
0000 08 00 11 11 11 00 08 00 11 11 22 22 08 88 11 22 ..........""..."
0010 33 44 55 66 77 88 88 77 66 55 44 33 22 11 09 01 3DUfw..wfUD3"...