TCP框架优点
(1)应答机制:TCP发送的每个报文段都必须得到接收方得应答才认为这个TCP报文段传输成功
(2)超时重发:发送端发出一个报文段之后,就启动定时器,如果在定时时间内没有收到应答就重新发送这个报文段
(3)错误校验:TCP会用一个校验的函数来检查数据是否有错误,在发送和接收的时候都会有校验
(4)流量管控和防阻塞管理:流量控制用来避免主机因为消息发送过快而来不及完全接受
搭建TCP框架步骤
(1)导入模块
(2)创建套接字
(3)设置地址可以重用
(4)绑定端口
(5)设置监听,套接字由主动变为被动
(6)接收客户端连接
(7)接受客户端发送的信息
(8)解码数据并输出
(9)关闭和当前客户端的连接
TCP框架实例
# 1.导入模块 import socket import threading def recv_msg(new_tcp_socket, ip_port): """ 接受信息的函数 :return: """ # 这个while可以不间断的接收客户端信息 while True: # 7.接受客户端发送的信息 recv_data = new_tcp_socket.recv(1024) if recv_data: # 8.解码数据并输出 recv_text = recv_data.decode('gbk') print('来自[%s]的信息:%s' % (str(ip_port), recv_text)) else: break # 关闭客户端连接 new_tcp_socket.close() # 2.创建套接字 tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 3.设置地址可以重用 tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) # 4.绑定端口 tcp_server_socket.bind(("", 8080)) # 5.设置监听,套接字由主动变为被动 tcp_server_socket.listen(128) # 用一个while True来接受多个客户端连接 while True: # 6.接收客户端连接 new_tcp_socket, ip_port = tcp_server_socket.accept() print('新用户[%s]连接' % str(ip_port)) # 创建线程 thread_msg = threading.Thread(target=recv_msg, args=(new_tcp_socket, ip_port)) # 子线程守护主线程 thread_msg.setDaemon(True) # 启动线程 thread_msg.start() # 调用接收函数 # recv_msg(new_tcp_socket, ip_port) # tcp_server_socket.close()
在学习了有关TCP的内容后,很多人对于这种编程的通信方式感兴趣,因为在应答和检验方便比较出色。结合我们最近在学习的python,可以在其中做一个TCP框架来使用。
以上就是使用python建立TCP框架的方法,大家可以进相关的搭建步骤进行学习,在对流程有一个明确后,再对搭建的代码部分展开练习。
神龙|纯净稳定代理IP免费测试>>>>>>>>天启|企业级代理IP免费测试>>>>>>>>IPIPGO|全球住宅代理IP免费测试