2015-05-07 56 views
1

像添加选项一旦收到TCP ACK(有选项实验)这个在TCP与Scapy的

​​

我要生成一个TCP SYN + ACK(可选择实验和快速打开的Cookie)下面

enter image description here

所示我想与Scapy的以生成所述TCP SYN + ACK,所以我说

,所以我在/ usr/share/pyshared/scapy/layers/inet.py添加254 : ("RFC3692-style Experiment","!HHH")这样

TCPOptions = (
       { 0 : ("EOL",None), 
       1 : ("NOP",None), 
       2 : ("MSS","!H"), 
       3 : ("WScale","!B"), 
       4 : ("SAckOK",None), 
       5 : ("SAck","!"), 
       8 : ("Timestamp","!II"), 
       14 : ("AltChkSum","!BH"), 
       15 : ("AltChkSumOpt",None), 
       25 : ("Mood","!p"), 
       254 : ("Experiment","!HHHH") 
       }, 
       { "EOL":0, 
       "NOP":1, 
       "MSS":2, 
       "WScale":3, 
       "SAckOK":4, 
       "SAck":5, 
       "Timestamp":8, 
       "AltChkSum":14, 
       "AltChkSumOpt":15, 
       "Mood":25, 
       "Experiment":254 
       }) 

并且在收到TCP ACK(带实验选项),我executhe以下Scapy的功能:

TCP_SYNACK=TCP(sport=Ddport, dport=Ssport, flags="SA", seq=SeqNr, ack=AckNr, options=[('Experiment',0xf989,0xcafe,0x0102,0x0002),('NOP',0),('NOP',0)]) 
ANSWER=sr1(ip/TCP_SYNACK) 

但我得到了一个python错误。它看起来像我在scapy的TCP数据包中的选项字段的定义中出错。我在做什么?

+0

我已经编辑[我的答案](http://stackoverflow.com/a/30128302/3903832),请评阅。我希望它能解决你的问题:-) – Yoel

回答

0

我认为你需要在tuple格式指定可选字段的值,如下所示:

TCP_SYNACK = TCP(sport=Ddport, dport=Ssport, flags="SA", seq=SeqNr, ack=AckNr, options=[('Experiment', (0xf989, 0xcafe, 0x0102, 0x0002)), ('NOP', 0), ('NOP', 0)]) 
0

,但我有同样的问题。实际上,您可以将整数作为选项元组的第一个元素。我希望把在哈希,所以我用下面的代码在Scapy的:

pkt = TCP(options=[("NOP", None), (19, "\xff\xff\xff\xff\xff\xff")])