TCP标志位

本文介绍了TCP标志位ACK、PSH、RST、SYN、FIN的含义,以及NULL标志的情况,还提到金山网镖日志报告使用标志位首字母。同时说明了一些特殊扫描方式可绕过不严谨的防火墙,最后阐述了基于这些标志位的TCP三次握手过程,握手完成后开始通讯。
TCP标志位
TCP标志位
URG:此标志表示TCP包的紧急指针域(后面马上就要说到)有效,用来保证TCP连接不被中断,并且督促中间层设备要尽快处理这些数据;

ACK:此标志表示应答域有效,就是说前面所说的TCP应答号将会包含在TCP数据包中;有两个取值:0和1,为1的时候表示应答域有效,反之为0;

PSH:这个标志位表示Push操作。所谓Push操作就是指在数据包到达接收端以后,立即传送给应用程序,而不是在缓冲区中排队;

RST:这个标志表示连接复位请求。用来复位那些产生错误的连接,也被用来拒绝错误和非法的数据包;

SYN:表示同步序号,用来建立连接。SYN标志位和ACK标志位搭配使用,当连接请求的时候,SYN=1,ACK=0;连接被相应的时候,SYN=1,ACK=1;这个标志的数据包经常被用来进行端口扫描。扫描者发送一个只有SYN的数据包,如果对方主机响应了一个数据包回来 ,就表明这台主机存在这个端口;但是由于这种扫描方式只是进行TCP三次握手的第一次握手,因此这种扫描的成功表示被扫描的机器不很安全,一台安全的主机将会强制要求一个连接严格的进行TCP的三次握手;

FIN:表示发送端已经达到数据末尾,也就是说双方的数据传送完成,没有数据可以传送了,发送FIN标志位的TCP数据包后,连接将被断开。这个标志的数据包也经常被用于进行端口扫描。当一个FIN标志的TCP数据包发送到一台计算机的特定端口,如果这台计算机响应了这个数据,并且反馈回来一个RST标志的TCP包,就表明这台计算机上没有打开这个端口,但是这台计算机是存在的;如果这台计算机没有反馈回来任何数据包,这就表明,这台被扫描的计算机存在这个端口。

需要说明的是,金山网镖的日志报告使用的不是这些标志位的全称,而是使用的这些标志位的首字母,比如拦截到一个包含FIN标志的TCP数据包将会报告x.x.x.x的TCP数据包:F。还有一点,你的日志可能报告x.x.x.x的TCP数据包:NULL,这是什么?NULL标明发送给你的数据包不包含任何标志位,你收到这种数据包,很多情况下意味着你被扫描,扫描者发送NULL数据包给你,如果你的计算机发送回去了一个FIN标志的TCP数据包,就表明他探测的端口在你的计算机上不存在,但是你的计算机就已经被确定存在了,这样他就可以使用其他的扫描方式进行端口探测。有一些特殊的扫描方式可以绕过不严谨的防火墙。

了解到了TCP标志位的含义,就可以了解TCP的三次握手是怎么进行的了:发送端发送一个SYN=1,ACK=0标志的数据包给接收端,请求进行连接,这是第一次握手;接收端收到请求并且允许连接的话,就会发送一个SYN=1,ACK=1标志的数据包给发送端,告诉它,可以通讯了,并且让发送端发送一个确认数据包,这是第二次握手;最后,发送端发送一个SYN=0,ACK=1的数据包给接收端,告诉它连接已被确认,这就是第三次握手。之后,一个TCP连接建立,开始通讯。

### TCP标志位的详细解析及其功能 TCP标志位TCP协议头部的一部分,用于控制数据传输的行为和状态。以下是TCP标志位的详细解析及其功能: #### 1. URG (Urgent) URG标志表示紧急指针字段有效。当该标志被设置时,表示当前数据中的数据需要被优先处理,通常用于实时通信场景中,确保数据会被延迟处理[^2]。 #### 2. ACK (Acknowledgment) ACK标志表示确认号字段有效。在TCP连接建立后,所有传送的报文段都必须将此标志置为1。它用于确认已接收到的数据,并通过确认号告诉发送方下一个期望接收的字节序号[^4]。 #### 3. PSH (Push) PSH标志表示要求接收方立即将数据提交给上层应用,而等待缓冲区填满。这通常用于提高实时性,避免数据延迟。例如,在交互式应用(如Telnet)中,每次按键产生的数据都会立即被发送[^3]。 #### 4. RST (Reset) RST标志用于复位连接。如果一个主机接收到一个错误的TCP数据(如目标端口存在或连接异常),它会发送一个带有RST标志的数据来终止连接。这种机制可以快速解决连接问题[^1]。 #### 5. SYN (Synchronize) SYN标志用于同步序列号,建立连接。在三次握手过程中,客户端和服务器通过交换SYN标志的数据来协商初始序列号。这是TCP连接建立的关键步骤之一[^4]。 #### 6. FIN (Finish) FIN标志用于关闭连接。当一方完成数据发送并希望关闭连接时,会发送一个带有FIN标志的数据。另一方接收到FIN后,会返回一个ACK确认,并在适当时候发送自己的FIN以完成四次挥手过程[^1]。 --- ### TCP标志位的应用示例 以下是一个简单的代码示例,展示如何使用Python的`scapy`库捕获并解析TCP标志位: ```python from scapy.all import sniff, TCP def analyze_tcp_flags(packet): if packet.haslayer(TCP): flags = packet[TCP].flags print(f"Captured TCP Flags: {flags}") if 'U' in flags: print("URG flag is set.") if 'A' in flags: print("ACK flag is set.") if 'P' in flags: print("PSH flag is set.") if 'R' in flags: print("RST flag is set.") if 'S' in flags: print("SYN flag is set.") if 'F' in flags: print("FIN flag is set.") sniff(filter="tcp", prn=analyze_tcp_flags, count=10) ``` 上述代码通过`scapy`库捕获网络中的TCP数据,并解析其中的标志位,输出每个标志位的状态。 --- ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值