[Internet上已经有一个代码,显示了如何使用原始套接字在Python中构建和发送TCP数据包,但是我急切地需要一个有关如何构建UDP的示例。
我阅读了此链接http://www.ietf.org/rfc/rfc768.txt,并了解udp标头仅由src ip,src端口,长度和校验和组成,并且还阅读了如果我创建IPPROTO_UDP套接字而不是IPPROTO_RAW套接字,则IP头应由内核。
但是,我这样做没有成功。
这是使用原始套接字构建tcp数据包的代码:
import socket
import struct
def make_ip(proto, srcip, dstip, ident=54321):
saddr = socket.inet_aton(srcip)
daddr = socket.inet_aton(dstip)
ihl_ver = (4 << 4) | 5
return struct.pack('!BBHHHBBH4s4s' ,
ihl_ver, 0, 0, ident, 0, 255, proto, 0, saddr, daddr)
def make_tcp(srcport, dstport, payload, seq=123, ackseq=0,
fin=False, syn=True, rst=False, psh=False, ack=False, urg=False,
window=5840):
offset_res = (5 << 4) | 0
flags = (fin | (syn << 1) | (rst << 2) |
(psh <<3) | (ack << 4) | (urg << 5))
return struct.pack('!HHLLBBHHH',
srcport, dstport, seq, ackseq, offset_res,
flags, window, 0, 0)
srcip = dstip = '127.0.0.1'
srcport, dstport = 11001, 11000
payload = '[TESTING]\n'
ip = make_ip(socket.IPPROTO_TCP, srcip, dstip)
tcp = make_tcp(srcport, dstport, payload)
packet = ip + tcp + payload
s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_RAW)
s.sendto(packet, (dstip, 0))
response, addr = s.recvfrom(65535)
response_id = struct.unpack('!H', response[4:6])
print response_id
如何用UDP做同样的事情?
对我来说最好的解决方案是编辑现有代码,因为阅读抽象信息对我没有多大帮助。
我在Windows XP上使用Python 2.7。
仅此:
import socket
sock = socket.socket(socket.AF_INET, # Internet
socket.SOCK_DGRAM) # UDP
sock.bind((IP,PORT))
发送:
sock.sendto(message,(IP,PORT))
接收:
sock.recvfrom(1024)
1024显示缓冲区大小。套接字部分没有其他必要的更改