2013-02-24 169 views
0

如何在SOCK_RAW格式的python中添加自定義字段,如IP和UDP標頭?我想在數據包中有一個自定義字段,並在計算中使用該字段。原始套接字編程UDP Python

+0

你用'SOCK_RAW'意味着什麼格式? – 2013-02-24 06:45:48

+0

如果您打算混淆IP格式,則需要更改所有內容---從操作系統到路由上的所有路由器。對於UDP,我不確定,但我認爲你也需要。爲什麼不採取安全的解決方案並在UDP數據中添加您的字段? – 2013-02-24 09:16:00

+0

我正在談論原始類型的套接字。並從頭開始構建數據包並編輯標題字段。感謝Mike和Rigo – empyreanphoenix 2013-02-24 16:42:18

回答

0

您沒有指定自定義字段的位置。這個例子可以讓你隨意打造UDP報頭(至少在Linux上 - 有可能是依賴於操作系統的行爲):

from socket import * 
import struct 
s = socket(AF_INET, SOCK_RAW, IPPROTO_UDP) 
data = 'string' 
sport = 4711 # arbitrary source port 
dport = 45134 # arbitrary destination port 
length = 8+len(data); 
checksum = 0 
udp_header = struct.pack('!HHHH', sport, dport, length, checksum) 
s.sendto(udp_header+data, ('', 0)); 

與測試:

 
# socat -u UDP:localhost:4711 - & 
# netstat -up 
Active Internet connections (w/o servers) 
Proto Recv-Q Send-Q Local Address   Foreign Address   State  PID/Program name 
udp  0  0 localhost:45134   localhost:4711   ESTABLISHED 2663/socat  
# tcpdump -ilo -vv -x 
11:32:07.409163 IP (tos 0x0, ttl 64, id 0, offset 0, flags [DF], proto UDP (17), length 34) 
localhost.4711 > localhost.45134: [no cksum] UDP, length 6 
    0x0000: 4500 0022 0000 4000 4011 3cc9 7f00 0001 
    0x0010: 7f00 0001 1267 b04e 000e 0000 7374 7269 
    0x0020: 6e67