TCP_Scanner
- TCP三次握手
- 第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,并进入SYN_SENT状态,等待服务器确认;SYN:同步序列编号(Synchronize
Sequence Numbers)。 - 第二次握手:服务器收到syn包,必须确认客户的SYN(ack=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入SYN_RECV状态;
- 第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED(TCP连接成功)状态,完成三次握手。
three times handshake、three-way handshake
- 完成三次握手,客户端与服务器开始传送数据
- 设想当我们直接发ACK置为的报文[第三次握手]会发生什么事?
无论目的端口是否开启,服务端都会觉得莫名其妙并发送一个RST置位的报文并断开连接!那么我们便可以通过这个特点来构造一个数据包,如果发送的ACK报文收到了回复,则证明目的的主机是存活的。
代码
from scapy.all import (
IP, //IP模块
TCP, //TCP模块
sr1 //三层数据包发送模块
)
import sys //导入系统模块
if l