先说一下:如果你使用Windows发不了,那就转Linux!能解决大部分问题。
首先你得装好impacket,怎么装就不用我说了吧。当然自己写构造的函数也可以。
TCP
import socket
import impacket.ImpactPacket
import warnings
warnings.filterwarnings("ignore")
s = socket.socket(socket.AF_INET,socket.SOCK_RAW,socket.IPPROTO_RAW)
ip = impacket.ImpactPacket.IP()
tcp = impacket.ImpactPacket.TCP()
ip.set_ip_src("192.168.3.16")#你的ip
ip.set_ip_dst("120.132.18.213")#目标ip
ip.set_ip_ttl(255)#ttl
tcp.set_th_flags(0b00000010)#将syn标志位设为1
tcp.set_th_sport(12228)#源端口
tcp.set_th_dport(80)#目标端口
tcp.set_th_ack(0)
tcp.set_th_seq(22903)
tcp.set_th_win(20000)#设置Window Size
ip.contains(tcp)
ip.calculate_checksum()
s.sendto(ip.get_packet(),("120.132.18.213",80))#两个参数分别为要发送的数据,类型为bytes与包含目标ip与端口的元祖
抓包结果: