当前位置: 首页 > article >正文

人工智能-Python网络编程-TCP

1 TCP-概念版

服务端
import socket
​
# 1 创建服务端套接字对象
#   socket.AF_INET IPV4
#   socket.SOCK_STREAM TCP
#   socket.SOCK_DGRAM UDP
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
​
# 2 绑定端口号
tcp_server_socket.bind(('192.168.124.7', 8888))
​
# 3 设置监听
#   参数为允许最大的连接数
tcp_server_socket.listen(1)
​
# 4 等待接收客户端的连接请求
new_socket, client_connect = tcp_server_socket.accept()
​
# 5 接收数据
recv_data = new_socket.recv(1024).decode(encoding='utf-8')
print(recv_data)
​
# 6 发送数据
new_socket.send('<服务器>: 已收到数据'.encode('utf-8'))
​
# 7 关闭套接字
tcp_server_socket.close()
客户端
import socket
​
# 1 创建套接字对象
#   socket.AF_INET IPV4
#   socket.SOCK_STREAM TCP
#   socket.SOCK_DGRAM UDP
tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
​
# 2 与服务器建立连接
tcp_client_socket.connect(('192.168.124.7', 8888))
​
# 3 发送数据(必须是字节流类型数据)
tcp_client_socket.send('<客户端>: 请求发送数据'.encode(encoding='utf-8'))
​
# 4 接收数据
recv_data = tcp_client_socket.recv(1024).decode(encoding='utf-8')
print(recv_data)
​
# 5 关闭套接字
tcp_client_socket.close()
​

2 TCP-基础对话版

服务端
import socket
​
IPV4_ADDR = '192.168.124.7'
IPV4_PORT = 8888
​
​
# TCP 服务端程序必须绑定端口号,否则客户端找不到这个 TCP 服务端程序
class ServerSocket(object):
    def __init__(self):
        # 1 创建服务端套接字对象
        #   socket.AF_INET IPV4
        #   socket.SOCK_STREAM TCP
        #   socket.SOCK_DGRAM UDP
        self.tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
​
        # 设置端口复用 如果程序执行结束,则让其占用的端口立即释放
        self.tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
​
        # 2 绑定端口号
        self.tcp_server_socket.bind((IPV4_ADDR, IPV4_PORT))
​
        # 3 设置监听
        # listen 后的套接字属于被动套接字,只负责接收新的客户端的连接请求不能收发消息
        #   参数为允许最大的连接数
        self.tcp_server_socket.listen(1)
​
    def start(self):
        while True:
            # 4 等待接收客户端的连接请求
            # 当 TCP 客户端程序和 TCP 服务端程序连接成功后,TCP 服务端程序会产生一个新的套接字,收发客户端消息使用该套接字
            client_socket, client_connect = self.tcp_server_socket.accept()
​
            while True:
                # 5 接收数据
                recv_data = client_socket.recv(1024).decode(encoding='utf-8')
                # 当客户端的套接字调用 close 后,服务器端的 recv 会解阻塞,返回的数据长度为0
                if len(recv_data) <= 0:
                    client_socket.close()
                print(f'接收到客户端 {client_connect[0]}:{client_connect[1]} 发来的消息: {recv_data}')
​
                # 6 发送数据
                send_data = input('(请输入消息按 Enter 键发送): ')
                if send_data in ('q', 'Q'):
                    # 7 关闭 客户-服务 套接字
                    client_socket.close()
                    break
                client_socket.send(send_data.encode('utf-8'))
​
    def __del__(self):
        # 5 关闭套接字
        self.tcp_server_socket.close()
​
​
if __name__ == '__main__':
    server_socket = ServerSocket()
    server_socket.start()
客户端 ​
import socket
​
IPV4_ADDR = '192.168.124.7'
IPV4_PORT = 8888
​
​
# TCP 客户端程序一般不需要绑定端口号,因为客户端是主动发起建立连接的
class ClientSocket():
    def __init__(self):
        while True:
            # 1 创建套接字对象
            #   socket.AF_INET IPV4
            #   socket.SOCK_STREAM TCP
            #   socket.SOCK_DGRAM UDP
            tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
​
            # 2 与服务器建立连接
            tcp_client_socket.connect((IPV4_ADDR, IPV4_PORT))
​
            while True:
                # 3 发送数据(必须是字节流类型数据)
                send_data = input('(请输入消息按 Enter 键发送): ')
                if send_data in ('q', 'Q'):
                    # 5 关闭套接字
                    tcp_client_socket.close()
                    return
                tcp_client_socket.send(send_data.encode(encoding='utf-8'))
​
                # 4 接收数据
                recv_data = tcp_client_socket.recv(1024).decode(encoding='utf-8')
                # 当服务端的套接字调用 close 后,客户端的 recv 会解阻塞,返回的数据长度为0
                if len(recv_data) <= 0:
                    tcp_client_socket.close()
                    return
                print(f'接收到服务端回复的消息: {recv_data}')
​
​
if __name__ == '__main__':
    socket = ClientSocket()


http://www.kler.cn/a/469031.html

相关文章:

  • C++二十三种设计模式之抽象工厂模式
  • python requests 415
  • Backend - EF Core(C# 操作数据库 DB)
  • 遗传学的“正反”之道:探寻生命密码的两把钥匙
  • ECCV`24 | 首次解决文本到3D NeRFs分解问题!港中文等提出DreamDissector
  • 小程序组件 —— 28 组件案例 - 推荐商品区域 - 实现结构样式
  • 数据库基础:SQL 与 NoSQL 的区别与应用场景
  • BERT的中文问答系统61
  • 桌面开发 的设计模式(Design Patterns)核心知识
  • Qt实现使用TCP与RS485串口设备通信————附带详细实践方法
  • KCP技术原理
  • HTML——77.网页编码及乱码处理
  • 深度学习之父
  • 会员制电商创新:开源 AI 智能名片与 2+1 链动模式的协同赋能
  • HTTP STATUS CODE详情,HTTP状态码大全列表
  • MYsql--------ubantu中安装mysql
  • 【顶刊TPAMI 2025】多头编码(MHE)之极限分类 Part 2:基础知识
  • 模型 九屏幕分析法
  • 麒麟服务器安装kafka--亲测
  • net core介绍
  • 六、Hadoop环境搭建之克隆虚拟机
  • go语言zero框架中教务crm系统的在职继承和离职交接的设计与实践
  • 求职:求职者在现场面试中应该注意哪些问题?
  • 设计模式学习[15]---适配器模式
  • visual studio 安全模式
  • 使用游戏CDN提升游戏流畅度:全面而专业的解析