Python网络编程入门

一.Socket

简称套接字,是进程之间通信的一个工具,好比现实生活中的插座,所有的家用电器要想工作都是基于插座进行,进程之间要想进行网络通信需要Socket,Socket好比数据的搬运工~

2个进程之间通过Socket进行相互通讯,就必须有服务端和客户端。

  • 服务端:等待其他进程的连接,可接受发来的消息、可以回复消息~
  • 客户端: 主动连接服务端,可以发送消息,可以接受回复~

一个服务端可以接受多个客户端发来的消息,如下图:

二.服务端开发

1.导入socket包

2.创建一个Socket对象

python 复制代码
socket_server = socket.socket()

3.绑定IP地址和端口

python 复制代码
socket_server.bind(('localhost', 1319))

端口号自定义,但别和nodejs、Jupyter、MySQL或者Tomcat这些重合了就行~

4.监听端口

python 复制代码
socket_server.listen(1)

函数内参数设置为1,表示同时最多接受1个客户端的连接。

5.等待客户端连接

这里使用accept方法,这是一个阻塞方法:如果没有连接,则后续的代码皆不执行~

python 复制代码
conn, addr = socket_server.accept()

accept返回的是一个二元元组:

  • conn:客户端和服务端的连接对象
  • address:客户端的地址信息

测试连接情况:

python 复制代码
print(f"Connected by: {addr}")

6.接受客户端信息

python 复制代码
data:str = conn.recv(1024).decode('utf-8')
#类型注释,字符串型

recv接受的参数是缓冲区大小,这里一般给1024即可。此外其返回值为一个字节数组也即bytes对象,需要decode方法通过UTF-8编码,将字节数组转换为字符串对象~

python 复制代码
print(f"message:{data}")

7.回复消息

python 复制代码
msg=input("回复消息:").encode('utf-8')
conn.send(msg)

input键入的是字符串对象,因此需要先编码为字节数组~

8.关闭链接

python 复制代码
conn.close()
socket_server.close()

三.客户端开发

总的来说异曲同工,甚至更为简易:

python 复制代码
import socket
socket_client= socket.socket()
socket_client.connect(('127.0.0.1', 1325))  #就是localhost,别犹豫
socket_client.send(bytes('Hello, client!', 'utf-8'))
recv_data=socket_client.recv(1024)
print(f"回复的消息是:{recv_data.decode('utf-8')}")
socket_client.close()

四.测试

将两个py文件都运行起来:

服务端已经收到了客户端发来的消息了,这时我们回复以后,客户端亦可正常收到~

相关推荐
haosend29 分钟前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽41 分钟前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
IVEN_18 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang20 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮20 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling20 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮1 天前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽1 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
YuMiao1 天前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议