- 三次握手建连接: 建立双向通道,建立好连接。 三次握手过程: 第一次握手:建立连接时,客户端发送syn包到服务器,并进入SYN_SENT状态,等待服务器确认 第二次握手:服务器收到syn包,确认客户的SYN,同时发送一个SYN包,即SYN+ACK包,此时服务器进入SYN_RECV状态; 第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=y+1),此包发送完毕,客户端和服务器进入ESTABLISHED(TCP连接成功)状态,完成三次握手。
- 四次挥手断连接:
第一次,客户端向服务端发出FIN请求,并且停止发送数据。客户端进入FIN-WAIT-1(终止等待1)状态。
第二次,服务器收到请求,发出ACK确认,服务端进入CLOSE-WAIT(关闭等待)状态。
等待,客户端收到服务器的确认后,此时,客户端就进入FIN-WAIT-2 (终止等待2)状态,等待服务器发送FIN请求(可能还需要接受服务器发送的最后的数据)。
第三次,服务器将最后的数据发送完毕后,向客户端发送FIN请求,服务器就进入了LAST-ACK(最后确认)状态,等待客户端的确认。
第四次,客户端收到服务器的FIN请求,发出ACK确认,客户端就进入了TIME-WAIT(时间等待)状态。(注意:此时TCP连接还没有释放,必须经过2MSL(最长报文段寿命)的时间后,当客户端撤销相应的TCB后,才进入CLOSED状态。服务器只要收到了客户端发出的确认,立即进入CLOSED状态。同样,撤销TCB后,就结束了这次的TCP连接。可以看到,服务器结束TCP连接的时间要比客户端早一些。)
2.基于TCP开发一款远程CMD程序
客户端连接服务器后,可以向服务器发送命令
服务器收到命令后执行,无论执行是否成功,无论执行几遍,都将执行结果返回给客户端
注意: 执行系统指令使用subprocess模块完成.
server 端代码:
import socket
import subprocess
server = socket.socket()
server.bind(
('127.0.0.1', 9527)
)
server.listen(5)
while True:
conn, addr = server.accept()
while True:
try:
# recv的数据是从内存中获取
cmd = conn.recv(1024).decode('utf-8')
if cmd == 'q':
break
if len(cmd) == 0:
continue
print(cmd)
# 执行cmd命令
obj = subprocess.Popen(
cmd,
shell=True,
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
)
result = obj.stdout.read() + obj.stderr.read()
conn.send(result)
except Exception as e:
print(e)
break
conn.close()
client 端代码
import socket
client = socket.socket()
client.connect(
('127.0.0.1', 9527)
)
while True:
cmd = input('》》》:') # dir
client.send(cmd.encode('utf-8'))
if cmd == 'q':
break
# 接受终端返回的结果
data = client.recv(10000000000).decode('gbk')
print(data)
client.close()
注意:用以上两段代码模拟客户端和服务器,代码要在两个命令框执行(python解释器不行),并且要先执行server,只有server开始监听了,client才能连接。