使用Python scapy发送TCP RST以防止客户端访问问题

问题描述 投票:0回答:2

我使用SCAPY编写部署在WEB服务器中的程序,并希望使用SCAPY发送TCP RST来阻止某些特定的HTTP客户端访问。

运行程序后,客户端使用Telnet连接服务器WEB监听端口可以SCAPY程序中断,但使用浏览器访问不能中断。为什么会这样?

代码如下:

# coding: utf-8

# web server  : 10.28.16.20 ;
# http client : 10.28.1.70;

from scapy.all import *
def pkgs(pkg):
    if pkg.getlayer(TCP) and pkg[IP].dst=="10.28.16.20" and "10.28.1.70" in pkg[IP].src:
        resp=IP(dst=pkg[IP].src,src=pkg[IP].dst)/TCP(dport=pkg[TCP].sport,sport=pkg[TCP].dport,flags="RA",seq=pkg[TCP].ack,ack=pkg[TCP].seq+(len(pkg[TCP].payload) if pkg.getlayer(Raw) else 1))
        send(resp,count=2,verbose=0)
if __name__=="__main__":
    conf.L3socket=L3RawSocket
    sniff(filter="tcp",prn=pkgs,store=0)

Program code screenshot

python scapy
2个回答
0
投票

我已经解决了它。进口线程。


0
投票

我认为最好的方法是进入“Scapy”,然后粘贴该代码并输入:

#!/usr/bin/python
from scapy.all import *
ip = IP(src="10.28.16.20", dst="10.28.1.70")
tcp = TCP(sport=80, dport=@@@@, flags=@@@@, seq=@@@@, ack=@@@@)
pkt = ip/tcp
ls(pkt)
send(pkt,verbose=0)

您需要将dport从PC更改为源端口,标记要执行的操作,seq&ack将跟随您启动的数据包。

© www.soinside.com 2019 - 2024. All rights reserved.