Python Socket

一、服务端

python 复制代码
from socket import *

def print_hi(name):
    print(f'Hi, {name}')
    # 允许所有ip连接
    IP = '0.0.0.0'
    # 端口
    PORT = 8003
    # 定义一次从socket缓冲区读入512个字节数据
    BUFFER_LEN = 1024
    # 实例化socket对象 listenSocket 用来监听的socket
    listenSocket = socket(AF_INET, SOCK_STREAM) #socket网络层使用ip协议和tcp协议
    # 绑定地址和端口
    listenSocket.bind((IP, PORT))
    # 处于监听状态
    listenSocket.listen(5) #5表示最多能接收5个等待连接的客户端
    print(f'服务端启动成功,在{PORT}端口等待客户端连接...')
    # dataSpcket 用来接收和发送数据的socket
    dataSocket, addr = listenSocket.accept()
    print('接受一个客户端连接:', addr)
    while True:
        try:
            # 尝试读取对方发送的消息
            recved = dataSocket.recv(BUFFER_LEN) #BUFLEN指定从接收缓冲里最多读取多少字节
            # 如果返回为空表示对方关闭了连接
            # 退出循环,结束消息收发
            if not recved:
                break
            # 读取的字节数据是bytes类型,需要解码为字符串
            info = recved.decode()
            print(f'服务端收到客服端发送的消息:{info}')
            #发送的数据类型必须是bytes,所以需要编码
            dataSocket.send(f'服务端接收到了消息 {info}'.encode())
        except Exception as r:
            print('发生异常程序终止,异常信息={%s}'%r)
            break
    dataSocket.close()
    listenSocket.close()

if __name__ == '__main__':
    print_hi('start...')

二、客户端

三、消息格式

消息边界

格式参考

相关推荐
SelectDB1 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
荣码9 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
金銀銅鐵20 小时前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li1 天前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸1 天前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学1 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
花酒锄作田2 天前
Pydantic校验配置文件
python
hboot2 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi2 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi2 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab