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

基于Python Socket的多线程聊天程序案例分析

程序概述

这是一个使用Python socket模块实现的多线程聊天程序,包含客户端(chat_client.py)和服务器(chat_server.py)两部分。程序实现了基本的客户端间消息转发功能。

服务器端分析 (chat_server.py)

核心功能

  1. 用户管理:使用字典user_dic存储所有连接的客户端,键是客户端地址(IP,端口),值是对应的socket连接对象。

  2. 消息转发:接收一个客户端的消息后,解析出目标客户端地址,并将消息转发给目标客户端。

代码结构

import socket
from threading import Threaduser_dic = {}  # 存储所有客户端连接def send_recv(client_conn, client_addr):# 处理客户端消息的主循环while True:res = client_conn.recv(1024).decode("utf-8")print(f"客户端发送的消息:{res}")# 解析目标客户端地址tu = (res.split(":")[0], int(res.split(":")[1]))client_conn2 = user_dic.get(tu)  # 获取目标客户端socketif client_conn2 is None:print("对方已下线")else:# 转发消息message = "%s账户对您说%s"%(client_addr[0], res.split(":")[2])client_conn2.send(message.encode("utf-8"))if __name__ == '__main__':server_socket = socket.socket()server_socket.bind(('172.16.1.4', 8081))server_socket.listen()while True:print("等待客户端连接")client_conn, client_addr = server_socket.accept()print("客户端连接成功")user_dic[client_addr] = client_conn  # 存储新客户端Thread(target=send_recv, args=(client_conn, client_addr)).start()

关键点

  1. 多线程处理:每个客户端连接都会创建一个新线程(Thread)来处理消息。

  2. 消息格式:服务器期望的消息格式为IP:端口:消息内容

  3. 用户字典user_dic全局存储所有活跃连接,便于消息转发。

客户端分析 (chat_client.py)

核心功能

  1. 消息发送:从控制台输入消息并发送到服务器。

  2. 消息接收:接收服务器转发的消息并显示。

代码结构

import socket
from threading import Threaddef send_msg(client_socket):while True:msg = input("请输入要发送的消息:\n")client_socket.send(msg.encode("utf-8"))def recv_msg(client_socket):while True:msg = client_socket.recv(1024).decode("utf-8")print(msg)if __name__ == '__main__':client_socket = socket.socket()client_socket.bind(("172.16.1.4", 8082))  # 绑定本地端口client_socket.connect(('172.16.1.4', 8081))  # 连接服务器print(client_socket.getsockname())  # 打印本地地址信息# 启动发送和接收线程Thread(target=send_msg, args=(client_socket,)).start()Thread(target=recv_msg, args=(client_socket,)).start()

关键点

  1. 双线程设计:一个线程负责发送消息,另一个负责接收消息。

  2. 绑定端口:客户端也绑定了固定端口(8082),这在实际应用中可能需要动态分配。

  3. 简单交互:通过控制台输入输出实现简单交互。

程序工作流程

  1. 服务器启动,监听8081端口

  2. 客户端启动,连接服务器,绑定8082端口

  3. 客户端A发送消息格式为目标IP:目标端口:消息内容

  4. 服务器解析消息,查找目标客户端B的连接

  5. 服务器将消息转发给客户端B

  6. 客户端B接收并显示消息

改进建议

  1. 消息协议:定义更完善的消息协议,如使用JSON格式包含发送者、接收者、消息内容等。

  2. 异常处理:添加更多异常处理,如连接断开、消息格式错误等。

  3. 动态端口分配:客户端端口可以动态分配,避免冲突。

  4. 心跳机制:检测客户端是否在线,及时清理user_dic中的无效连接。

  5. 日志记录:添加日志功能,便于调试和问题追踪。

总结

这个程序展示了Python socket和多线程编程的基本应用,实现了简单的客户端间消息转发功能。虽然功能相对简单,但包含了网络编程的核心概念,适合作为学习案例。读者可以在此基础上扩展更复杂的功能,如群聊、文件传输、用户认证等。

http://www.xdnf.cn/news/68833.html

相关文章:

  • 一页概览:虚拟机的备份
  • 一周学会Pandas2 Python数据处理与分析-Pandas2索引标签操作
  • 多模态大语言模型arxiv论文略读(三十三)
  • 实时进程简单说明
  • Vue-组件的懒加载,按需加载
  • Vue的模板语法——指令语法
  • OpenCV第5课 图像的基本操作
  • 模拟车辆变道 python 可视化
  • Redis——持久化
  • odoo-047 ValueError: 字段 `attachment_location` 不存在
  • 解锁编程新技能:深入理解泛型类型和函数
  • 【图像标注技巧】目标检测图像标注技巧
  • MySQL5.7 生成日期工具表
  • day2 python训练营
  • 智能照明系统:照亮智慧生活的多重价值
  • 华为盒式交换机堆叠配置
  • llama-webui docker实现界面部署
  • OpenCV 图形API(47)颜色空间转换-----将 I420(YUV 4:2:0) 格式的图像数据转换为 RGB 格式
  • 你学会了些什么220310?--接口压测调研
  • ThreadLocal的那些杂事
  • 2025.4.21日学习笔记 JavaScript String、Array、date、math方法的使用
  • spark—SQL3
  • [免费]SpringBoot+Vue博物馆(预约)管理系统【论文+源码+SQL脚本】
  • 华为数字化转型“三阶十二步法“:战略驱动、系统布局与敏捷落地的实践框架
  • 29个常见的Terraform 面试问题
  • <数据集>小船识别数据集<目标检测>
  • Python基础总结(九)之推导式
  • AI 赋能企业架构之路:五大关键路标点深度剖析
  • C++ 封装成DLL,C#调用
  • 数字虹膜:无网时代的视觉密语 | 讨论