python的tkinter、socket库开发tcp的客户端和服务端
一、tcp通讯流程和开发步骤
1、tcp客户端和服务端通讯流程图
套接字是通讯的利器,连接时要经过三次握手建立连接,断开连接要经过四次挥手断开连接。
2、客户端开发流程
1)创建客户端套接字
2)和服务端器端套接字建立连接
3)发送数据
4)接收数据
5)关闭客户端套接字
3、服务端开发流程
1)创建服务端套接字
2)绑定ip和端口号
3)设置监听
4)等待客户端连接
5)接收数据
6)发送数据
7)关闭套接字
二、客户端的实现
使用python的tkinter库实现图形化界面,使用类来实现tcp的客户端和服务端
1、构造方法__init__初始化图形界面
设置了三个按钮
1)连接服务器的按钮: 用来发送请求连接服务端。
2)断开连接按钮:用来关闭连接。
3)发送消息按钮:来向服务端发送消息。
2、连接服务器的函数
1) tk.messagebox.showinfo: 弹窗,用来提示用户。
2)socket.socket(socket.AF_INET, socket.SOCK_STREAM): 创建套接字。
参数1:ipv4协议,参数2:表示tcp协议
3)tcp_client_socket.connect(): 连接服务端,参数必须是一个元组。
3、发送消息函数
1)send_entry.get(): 获取输入框的内容。
2)encode():编码。
3)tcp_client_socket.send(): 发送数据。
4)Thread(): 创建线程,防止阻塞。
参数1:target=要执行的函数,参数2:守护主线程。
5) .start(): 开启线程。
4、接收消息函数
recv_data = tcp_client_socket.recv(1024).decode('utf-8'): 接收消息并解码。
5、断开连接函数
tcp_client_socket.close(): 关闭客户端套接字。
三、服务端的实现
1、构造方法__init__初始化图形界面
设置了四个按钮:
1)启动服务端按钮:用来初始化服务端。
2)接收连接按钮:接收客户端请求的连接。
3)接收消息按钮:接收客户端发来的消息,需要手动接收。
4)发送消息按钮:向客户端发送消息。
2、启动服务端函数
1)tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM):创建服务器端套接字对象。
2)tcp_server_socket.bind(("", 8888)): 绑定IP地址与端口号,端口可以自行设置,但客户端必须和服务端保持一致。
3)tcp_server_socket.listen(5):监听连接,5表示最大连接数。
3、接收连接函数
conn_socket, ip_port = tcp_server_socket.accept():等待接收客户端连接请求。
4、发送消息函数
conn_socket.send(): 发送数据
5、接收消息函数
conn_socket.recv(1024).decode():接收数据并解码
conn_socket.close(): 关闭连接
tcp_server_socket.close():关闭套接字
四、效果图
使用说明:
1、先启动服务端,在启动客户端,再服务端点击接收连接按钮接收客户端发来的连接请求
2、客户端输入消息,点击发送消息
3、服务端点击接收消息,就会在下发文本框显示消息
4、服务端回消息,客户端会自动接收消息并显示在下方的文本框
五、代码
1、客户端
import socket
import tkinter as tk
import tkinter.messagebox
from threading import Thread# 创建tcp客户端
class TcpClientSocket:def __init__(self):self.tcp_client_socket = Noneself.root = tk.Tk()self.root.title('tcp客户端')self.root.geometry('500x350')# 连接self.con_btn = tk.Button(self.root, text="连接服务端", width=10, command=self.connect)self.con_btn.place(x=100, y=20)# 断开连接self.discon_btn = tk.Button(self.root, text="断开连接", width=10, command=self.disconnect)self.discon_btn.place(x=300, y=20)# 文本输入框self.send_entry = tk.Entry(self.root, width=50)self.send_entry.place(x=50, y=80)# 发送消息按钮self.send_btn = tk.Button(self.root, text="发送消息", command=self.send)self.send_btn.place(x=420, y=75)# 消息框self.msg_test = tk.Text(self.root, width=70, height=16)self.msg_test.place(x=2, y=125)self.root.mainloop()# 连接服务端def connect(self):try:if self.tcp_client_socket:tk.messagebox.showinfo('提示', '已是连接状态')# 每次连接服务端就将上一次的记录清除self.msg_test.delete(1.0, tk.END)self.send_entry.delete(0, tk.END)# 创建客户端socketself.tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 连接,端口可以改变self.tcp_client_socket.connect(('127.0.0.1', 8888))self.msg_test.insert(tk.END, "连接到服务端, 请输入信息...\n")except Exception as e:self.msg_test.insert(tk.END, f"连接失败的原因是: {e}")# 发送消息def send(self):# 从输入框获取数据input_data = self.send_entry.get()self.tcp_client_socket.send(input_data.encode(encoding='utf-8'))self.msg_test.insert(tk.END, f"客户端:{str(input_data)}\n")# 使用线程,防止未响应receive_thread = Thread(target=self.receive, daemon=True)receive_thread.start()def receive(self):if self.tcp_client_socket:rec_msg = self.tcp_client_socket.recv(1024).decode(encoding='utf-8')self.msg_test.insert(tk.END, f"服务端:{str(rec_msg)}\n")# 断开连接def disconnect(self):if self.tcp_client_socket:self.send_entry.delete(0, tk.END)self.msg_test.insert(tk.END, "断开连接")self.tcp_client_socket.send('#'.encode(encoding='utf-8')) # 发送’#‘断开连接self.tcp_client_socket.close() # 关闭客户端else:tk.messagebox.showinfo('提示', '未连接到服务端')if __name__ == '__main__':TcpClientSocket()
2、服务端
import socketimport tkinter as tk
from threading import Thread
import tkinter.messageboxclass TcpServerSocket:def __init__(self):self.conn_socket = Noneself.tcp_server_socket = Noneself.root = tk.Tk()self.root.title('tcp服务端')self.root.geometry('500x350')# 连接self.con_btn = tk.Button(self.root, text="启动服务端", width=10, command=self.start_server)self.con_btn.place(x=100, y=20)# 接收消息self.status_btn = tk.Button(self.root, text="接收连接", width=10, command=self.status)self.status_btn.place(x=200, y=20)# 接收消息self.rev_btn = tk.Button(self.root, text="接收消息", command=self.receive)self.rev_btn.place(x=300, y=20)# 文本输入框self.send_entry = tk.Entry(self.root, width=50)self.send_entry.place(x=50, y=80)# 发送消息按钮self.send_btn = tk.Button(self.root, text="发送消息", command=self.send)self.send_btn.place(x=420, y=75)# 消息框self.msg_test = tk.Text(self.root, width=70, height=16)self.msg_test.place(x=2, y=125)self.root.mainloop()# 启动tcp服务端def start_server(self):try:# 每次连接服务端就将上一次的记录清除self.send_entry.delete(0, tk.END)self.msg_test.delete(1.0, tk.END)# 创建服务端socketself.tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)self.tcp_server_socket.bind(('', 8888)) # 绑定self.tcp_server_socket.listen(5) # 监听的最大连接数self.msg_test.insert(tk.END, f"服务端启动成功!\n")except Exception as e:self.msg_test.insert(tk.END, f"启动失败的原因是: {e}")def status(self):if self.conn_socket is None:self.conn_socket, ip_port = self.tcp_server_socket.accept()elif self.conn_socket:self.msg_test.insert(tk.END, "客户端已连接\n")else:tk.messagebox.showinfo('提示', "客户端未连接")def send(self):try:input_data = self.send_entry.get()self.conn_socket.send(input_data.encode(encoding='utf-8'))self.msg_test.insert(tk.END, f"服务端:{str(input_data)}\n")except Exception as e:self.msg_test.insert(tk.END, f"发送失败的原因: {e}")def receive(self):rec_msg = self.conn_socket.recv(1024).decode(encoding='utf-8')print(rec_msg)# 获取到#断开连接if rec_msg == '#':self.conn_socket.close()self.tcp_server_socket.close()self.msg_test.insert(tk.END, f"客户端断开连接\n")returnself.msg_test.insert(tk.END, f"客户端:{str(rec_msg)}\n")if __name__ == '__main__':TcpServerSocket()
相关文章:

python的tkinter、socket库开发tcp的客户端和服务端
一、tcp通讯流程和开发步骤 1、tcp客户端和服务端通讯流程图 套接字是通讯的利器,连接时要经过三次握手建立连接,断开连接要经过四次挥手断开连接。 2、客户端开发流程 1)创建客户端套接字 2)和服务端器端套接字建立连接 3&#x…...
Python面试题:Python中的异步编程:详细讲解asyncio库的使用
Python 的异步编程是实现高效并发处理的一种方法,它使得程序能够在等待 I/O 操作时继续执行其他任务。在 Python 中,asyncio 库是实现异步编程的主要工具。asyncio 提供了一种机制来编写可以在单线程内并发执行的代码,适用于 I/O 密集型任务。…...

【信号频率估计】MVDR算法及MATLAB仿真
目录 一、MVDR算法1.1 简介1.2 原理1.3 特点1.3.1 优点1.3.2 缺点 二、算法应用实例2.1 信号的频率估计2.2 MATLAB仿真代码 三、参考文献 一、MVDR算法 1.1 简介 最小方差无失真响应(Mininum Variance Distortionless Response,MVDR)算法最…...

HarmonyOS NEXT零基础入门到实战-第二部分
HarmonyOS NEXT零基础入门到实战-第二部分 Swiper 轮播组件 Swiper是一个 容器 组件,当设置了多个子组件后,可以对这些 子组件 进行轮播显示。(文字、图片...) 1、Swiper基本语法 2、Swiper常见属性 3、Swiper样式自定义 4、案例&…...

《小程序02:云开发之增删改查》
一、前置操作 // 一定要用这个符号包含里面的${}才会生效 wx.showToast({title: 获取数据成功:${colorLista}, })1.1:初始化介绍 **1、获取数据库引用:**在开始使用数据库 API 进行增删改查操作之前,需要先获取数据库的引用 cons…...

SQL执行流程、SQL执行计划、SQL优化
select查询语句 select查询语句中join连接是如何工作的? 1、INNER JOIN 返回两个表中的匹配行。 2、LEFT JOIN 返回左表中的所有记录以及右表中的匹配记录。 3、RIGHT JOIN 返回右表中的所有记录以及左表中的匹配记录。 4、FULL OUTER JOIN 返回左侧或右侧表中有匹…...
【前端】JavaScript入门及实战41-45
文章目录 41 嵌套的for循环42 for循环嵌套练习(1)43 for循环嵌套练习(2)44 break和continue45 质数练习补充 41 嵌套的for循环 <!DOCTYPE html> <html> <head> <title></title> <meta charset "utf-8"> <script type"…...

更加深入Mysql-04-MySQL 多表查询与事务的操作
文章目录 多表查询内连接隐式内连接显示内连接 外连接左外连接右外连接 子查询 事务事务隔离级别 多表查询 有时我们不仅需要一个表的数据,数据可能关联到俩个表或者三个表,这时我们就要进行夺标查询了。 数据准备: 创建一个部门表并且插入…...
基于最新版的flutter pointycastle: ^3.9.1的AES加密
基于最新版的flutter pointycastle: ^3.9.1的AES加密 自己添加pointycastle: ^3.9.1库config.dartaes_encrypt.dart 自己添加pointycastle: ^3.9.1库 config.dart import dart:convert; import dart:typed_data;class Config {static String password 成都推理计算科技; // …...
K8S内存资源配置
在 Kubernetes (k8s) 中,资源请求和限制用于管理容器的 CPU 和内存资源。配置 CPU 和内存资源时,使用特定的单位来表示资源的数量。 CPU 资源配置 CPU 单位:Kubernetes 中的 CPU 资源以 “核” (cores) 为单位。1 CPU 核心等于 1 vCPU/Core…...

【多任务YOLO】 A-YOLOM: You Only Look at Once for Real-Time and Generic Multi-Task
You Only Look at Once for Real-Time and Generic Multi-Task 论文链接:http://arxiv.org/abs/2310.01641 代码链接:https://github.com/JiayuanWang-JW/YOLOv8-multi-task 一、摘要 高精度、轻量级和实时响应性是实现自动驾驶的三个基本要求。本研究…...
数学建模--灰色关联分析法
目录 简介 基本原理 应用场景 优缺点 优点: 缺点: 延伸 灰色关联分析法在水质评价中的具体应用案例是什么? 如何克服灰色关联分析法在主观性强时的数据处理和改进方法? 灰色关联分析法与其他系统分析方法(如A…...

NetSuite Saved Search迁移工具
我们需要在系统间迁移Saved Search,但是采用Copy To Account或者Bundle时,会有一些Translation不能迁移,或者很多莫名其妙的Dependency,导致迁移失败。因此,我们想另辟蹊径,借助代码完成Saved Search的迁移…...

Java IO模型深入解析:BIO、NIO与AIO
Java IO模型深入解析:BIO、NIO与AIO 一. 前言 在Java编程中,IO(Input/Output)操作是不可或缺的一部分,它涉及到文件读写、网络通信等方面。Java提供了多种类和API来支持这些操作。本文将从IO的基础知识讲起ÿ…...

《从C/C++到Java入门指南》- 9.字符和字符串
字符和字符串 字符类型 Java 中一个字符保存一个Unicode字符,所以一个中文和一个英文字母都占用两个字节。 // 计算1 .. 100 public class Hello {public static void main(String[] args) {char a A;char b 中;System.out.println(a);System.out.println(b)…...

Adobe国际认证详解-视频剪辑
在数字化时代,视频剪辑已成为创意表达和视觉传播的重要手段。随着技术的不断进步,熟练掌握视频剪辑技能的专业人才需求日益增长。在这个背景下,Adobe国际认证应运而生,成为全球创意设计领域的重要标杆。 Adobe国际认证是由Adobe公…...

昇思25天学习打卡营第19天|MindNLP ChatGLM-6B StreamChat
文章目录 昇思MindSpore应用实践ChatGML-6B简介基于MindNLP的ChatGLM-6B StreamChat Reference 昇思MindSpore应用实践 本系列文章主要用于记录昇思25天学习打卡营的学习心得。 ChatGML-6B简介 ChatGLM-6B 是由清华大学和智谱AI联合研发的产品,是一个开源的、支持…...
.NET在游戏开发中有哪些成功的案例?
简述 在游戏开发的多彩世界中,技术的选择往往决定了作品的成败。.NET技术,以其跨平台的性能和强大的开发生态,逐渐成为游戏开发者的新宠。本文将带您探索那些利用.NET技术打造出的著名游戏案例,领略.NET在游戏开发中的卓越表现。 …...
搜维尔科技:我们用xsens完成了一系列高难度的运动项目并且捕获动作
我们用xsens完成了一系列高难度的运动项目并且捕获动作 搜维尔科技:我们用xsens完成了一系列高难度的运动项目并且捕获动作...
深入探讨:Node.js、Vue、SSH服务与SSH免密登录
在这篇博客中,我们将深入探讨如何在项目中使用Node.js和Vue,并配置SSH服务以及实现SSH免密登录。我们会一步步地进行讲解,并提供代码示例,确保你能轻松上手。 一、Node.js 与 Vue 的结合 1.1 Node.js 简介 Node.js 是一个基于 …...

Unity3D中Gfx.WaitForPresent优化方案
前言 在Unity中,Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染(即CPU被阻塞),这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案: 对惹,这里有一个游戏开发交流小组&…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
Frozen-Flask :将 Flask 应用“冻结”为静态文件
Frozen-Flask 是一个用于将 Flask 应用“冻结”为静态文件的 Python 扩展。它的核心用途是:将一个 Flask Web 应用生成成纯静态 HTML 文件,从而可以部署到静态网站托管服务上,如 GitHub Pages、Netlify 或任何支持静态文件的网站服务器。 &am…...
【C语言练习】080. 使用C语言实现简单的数据库操作
080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...
在鸿蒙HarmonyOS 5中使用DevEco Studio实现录音机应用
1. 项目配置与权限设置 1.1 配置module.json5 {"module": {"requestPermissions": [{"name": "ohos.permission.MICROPHONE","reason": "录音需要麦克风权限"},{"name": "ohos.permission.WRITE…...
服务器--宝塔命令
一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行! sudo su - 1. CentOS 系统: yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...

人工智能(大型语言模型 LLMs)对不同学科的影响以及由此产生的新学习方式
今天是关于AI如何在教学中增强学生的学习体验,我把重要信息标红了。人文学科的价值被低估了 ⬇️ 转型与必要性 人工智能正在深刻地改变教育,这并非炒作,而是已经发生的巨大变革。教育机构和教育者不能忽视它,试图简单地禁止学生使…...
C语言中提供的第三方库之哈希表实现
一. 简介 前面一篇文章简单学习了C语言中第三方库(uthash库)提供对哈希表的操作,文章如下: C语言中提供的第三方库uthash常用接口-CSDN博客 本文简单学习一下第三方库 uthash库对哈希表的操作。 二. uthash库哈希表操作示例 u…...

windows系统MySQL安装文档
概览:本文讨论了MySQL的安装、使用过程中涉及的解压、配置、初始化、注册服务、启动、修改密码、登录、退出以及卸载等相关内容,为学习者提供全面的操作指导。关键要点包括: 解压 :下载完成后解压压缩包,得到MySQL 8.…...

AI语音助手的Python实现
引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...