1

我已经构建了一个数据包scapy

a=IP(dst='192.168.0.1',proto=1)/'\x08\x00\xf7\xff\x00\x00\x00\x00'

我跑:

send(a)

Wireshark 向我显示来自 192.168.0.1 的 ping 请求和 ping 响应没有警告,所有字段都正确

但是当我尝试时:

b=sr1(a)

然后 Scapy 无法得到答案(Wireshark 再次向我显示有请求和回复)

我能用它做什么?

4

1 回答 1

3

问题是它scapy不知道如何识别响应,因为您诚实地构建了一个 ICMP 数据包。如果你用 构建它ICMP(),它将工作......

>>> from scapy.all import ICMP, IP, sr1
>>> aa = IP(dst='192.168.0.1')/ICMP()
>>> sr1(aa)
Begin emission:
Finished to send 1 packets.
*
Received 1 packets, got 1 answers, remaining 0 packets
<IP  version=4L ihl=5L tos=0x0 len=28 id=21747 flags= frag=0L ttl=60 proto=icmp 
chksum=0x1a77 src=192.168.0.1 dst=4.121.2.25 options=[] |<ICMP  type=echo-reply 
code=0 chksum=0x0 id=0x0 seq=0x0 |<Padding  
load='\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00' |>>>
>>>
于 2011-05-09T06:24:19.403 回答