python之TCP的网络应用程序开发

文章目录

  • 版权声明
  • python3编码转换
  • socket类的使用
    • 创建Socket对象
    • Socket对象常用方法和参数
    • 使用示例
      • 服务器端代码
      • 客户端代码
  • TCP客户端程序开发流程
  • TCP服务端程序开发流程
  • TCP网络应用程序注意点
  • socket之send和recv原理剖析
    • send原理剖析
    • recv原理剖析
    • send和recv原理剖析图
  • 多任务版TCP服务端程序开发

版权声明

  • 本博客的内容基于我个人学习黑马程序员课程的学习笔记整理而成。我特此声明,所有版权属于黑马程序员或相关权利人所有。本博客的目的仅为个人学习和交流之用,并非商业用途。
  • 我在整理学习笔记的过程中尽力确保准确性,但无法保证内容的完整性和时效性。本博客的内容可能会随着时间的推移而过时或需要更新。
  • 若您是黑马程序员或相关权利人,如有任何侵犯版权的地方,请您及时联系我,我将立即予以删除或进行必要的修改。
  • 对于其他读者,请在阅读本博客内容时保持遵守相关法律法规和道德准则,谨慎参考,并自行承担因此产生的风险和责任。本博客中的部分观点和意见仅代表我个人,不代表黑马程序员的立场。

python3编码转换

  • 在网络传输数据的时候,数据需要先编码转化为二进制(bytes)数据类型
    在这里插入图片描述
函数名说明
encode编码 将字符串转化为字节码
decode解码 将字节码转化为字符串
  • encoed()和decode()函数可以接受参数,encoding是指在编解码过程中使用的编码方案。
    bytes.decode(encoding=“utf-8)
    str.encode(encoding=”utf-8)
    

socket类的使用

  • Python的 socket 类是Python标准库的一部分,用于提供对低级网络接口的访问。支持IPv4、IPv6、TCP、UDP等协议,允许创建基于网络的应用程序,如服务器和客户端。

创建Socket对象

  • 要使用 socket 类,首先需要导入 socket 模块,然后创建一个 socket 对象。可以通过调用 socket.socket() 方法并传递相应的参数来创建一个socket。
    import socket
    # 创建一个socket对象,默认是IPv4和TCP协议
    # socket.socket(AddressFamily, Type)
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    

Socket对象常用方法和参数

方法/参数类型/描述示例/默认值说明
socket()构造函数用于创建socket对象
family参数socket.AF_INET地址族,确定了socket的类型(IPv4或IPv6)
type参数socket.SOCK_STREAM指定了socket的通信类型(TCP或UDP)
proto参数0协议编号,默认为0,由系统选择合适的协议
fileno参数None可以指定一个文件描述符
bind(address)方法绑定地址到socket
address参数('localhost', 12345)一个包含主机名和端口号的元组
listen(backlog)方法开始监听传入连接
backlog参数5定义了等待队列的大小
accept()方法接受一个连接,返回(conn, address)
connect(address)方法用于客户端连接服务器
send(bytes)方法发送数据,参数为字节数据
recv(bufsize)方法接收数据,指定最大数据量
bufsize参数1024接收数据的缓冲区大小
close()方法关闭socket连接

使用示例

服务器端代码

import socket# 创建socket对象
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 绑定地址(host,port)
server_socket.bind(('localhost', 12345))# 开始监听
server_socket.listen()print("服务器启动,等待连接...")# 接受连接
connection, address = server_socket.accept()
print(f"连接来自 {address}")# 接收数据
data = connection.recv(1024)
print(f"接收到的数据: {data.decode()}")# 发送数据
connection.send("Hello, client!".encode())# 关闭连接
connection.close()

客户端代码

import socket# 创建socket对象
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 连接服务器
client_socket.connect(('localhost', 12345))# 发送数据
client_socket.send("Hello, server!".encode())# 接收数据
data = client_socket.recv(1024)
print(f"接收到的数据: {data.decode()}")# 关闭连接
client_socket.close()

这仅仅是一个非常简单的例子,实际应用中还需要处理错误、多线程或多进程处理多个连接、非阻塞IO等复杂情况。

TCP客户端程序开发流程

  • TCP网络应用程序开发分为:

    • TCP客户端程序开发,运行在服务器设备上的程序,专门为客户端提供数据服务。
    • TCP服务端程序开发,运行在用户设备上的程序
  • TCP客户端程序开发流程

    1. 创建客户端套接字对象(买电话)
    2. 和服务端套接字建立连接(打电话)
    3. 发送数据(说话)
    4. 接收数据(接听)
    5. 关闭客户端套接字(挂电话)
      在这里插入图片描述
  • TCP客户端开发程序流程

    1. 创建客户端套接字对象
    2. 和服务端套接字建立连接
    3. 发送数据
    4. 接收数据
    5. 关闭客户端套接字
import socketif __name__ == '__main__':# 1.创建客户端套接字对象tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 2.和服务端套接字建立连接tcp_client_socket.connect(("localhost", 8080))# 3.发送数据tcp_client_socket.send("hello".encode(encoding="utf-8"))# 4.接收数据 recv阻塞等待数据的到来recv_data = tcp_client_socket.recv(1024)print(recv_data.decode())# 5.关闭客户端套接字tcp_client_socket.close()

TCP服务端程序开发流程

在这里插入图片描述

  1. 创建服务端端套接字对象
  2. 绑定IP地址和端口号
  3. 设置监听
  4. 等待接受客户端的连接请求
  5. 接收数据
  6. 发送数据
  7. 关闭套接字
import socketif __name__ == '__main__':# 1.创建服务端套接字对象tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 2. 绑定IP地址和端口号# bind中的参数第一个ip地址元素设置为"",默认为本机ip地址tcp_server_socket.bind(("", 8080))# 3.设置监听 128:代表服务端等待排队连接的最大数量tcp_server_socket.listen(128)# 4.等待接受客户端的连接请求 accept阻塞等待 返回一个用以和客户端通socket,客户端的地址conn_socket, ip_port = tcp_server_socket.accept()print("客户端地址:", ip_port)# 5.接收数据recv_data = conn_socket.recv(1024)print("接收到的数据:", recv_data.decode())# 6.发送数据conn_socket.send("客户端你的数据我收到了".encode())# 7.关闭套接字conn_socket.close()tcp_server_socket.close()

TCP网络应用程序注意点

  1. 当TCP客户端程序想要和TCP服务端程序进行通信的时候必须要先建立连接
  2. TCP客户端程序一般不需要绑定端口号,因为客户端是主动发起建立连接的
  3. TCP服务端程序必须绑定端口号,否则客户端找不到这个TCP服务端程序。
  4. listen后的套接字是被动套接字,只负责接收新的客户端的连接请求,不能收发消息
  5. 当TCP客户端程序和TCP服务端程序连接成功后,TCP服务器端程序会产生一个新的套接字,收发客户端消息使用该套接字.
  6. 关闭accept返回的套接字意味着和客户端已经通信完毕当客户端的套接字调用close后,服务器端的recv会解阻塞,返回的数据长度为0,服务端可以通过返回数据的长度来判断客户端是否已经下线,反之服务端关闭套接字,客户端的recv也会解阻塞,返回的数据长度也为0。

socket之send和recv原理剖析

  • 当创建一个TCP socket对象的时候会有一个发送缓冲区和一个接收缓冲区,这个发送和接收缓冲区指的就是内存中的一片空间。

send原理剖析

  • send发送数据给服务端:必须得通过网卡发送数据,应用程序是无法直接通过网卡发送数据的,它需要调用操作系统接口,也就是说,应用程序把发送的数据先写入到发送缓冲区(内存中的一片空间),再由操作系统控制网卡把发送缓冲区的数据发送给服务端网卡。

recv原理剖析

  • recv从客户端接收数据:应用软件是无法直接通过网卡接收数据的,它需要调用操作系统接口,由操作系统通过网卡接收数据,把接收的数据写入到接收缓冲区(内存中的一片空间),应用程序再从接收缓存区获取客户端发送的数据。

send和recv原理剖析图

在这里插入图片描述

  • 不管是recv还是send都不是直接接收到对方的数据和发送数据到对方,发送数据会写入到发送缓冲区,接收数据是从接收缓冲区来读取,发送数据和接收数据最终是由操作系统控制网卡来完成。

多任务版TCP服务端程序开发

  • 实现步骤分析:
    在这里插入图片描述
  1. 编写一个TCP服务端程序,循环等待接受客户端的连接请求

    while True:service_client_socket, ip_port = tcp_server_socket.accept()
    
  2. 当客户端和服务端建立连接成功,创建子线程,使用子线程专门处理客户端的请求,防止主线程阻塞

while True:service_client_socket, ip_port = tcp_server_socket.accept()sub_thread = threading.Thread(target=handle_client_request, args=(service_client_socket, ip_port))sub_thread.start()
  • 完整代码:
import socket
import threading# 处理客户端函数
def handle_client(conn_socket):# 5.接收数据recv_data = conn_socket.recv(1024)print("接收到的数据:", recv_data.decode())# 6.发送数据conn_socket.send("收到客户端数据:".encode())# 7.关闭套接字conn_socket.close()# 1 使用循环接收客户端的连接请求
if __name__ == '__main__':# 1.创建服务端套接字对象tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 设置端口号复用,让程序退出端口号立即释放tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)# 2. 绑定IP地址和端口号# 如果bind中的参数第一个ip地址元素设置为"",默认为本机ip地址tcp_server_socket.bind(("", 8888))# 3.设置监听 128:代表服务端等待排队连接的最大数量tcp_server_socket.listen(128)while True:# 4.等待接受客户端的连接请求 accept阻塞等待 返回一个用以和客户端通socket,客户端的地址conn_socket, ip_port = tcp_server_socket.accept()print("客户端地址:", ip_port)# 使用多线程去接收多个客户端的请求 设置守护主线程sub_thread = threading.Thread(target=handle_client, args=(conn_socket,), daemon=True)sub_thread.start()tcp_server_socket.close()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/212623.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于单片机的光伏发电并网系统设计(论文+源码)

1.系统设计 片作为主控制器。由于太阳能板本身的能量输出受到负载影响,因此需要在太阳能板后面加入一级DC/DC电路,来实现最大功率跟踪,以提高整个系统的效率。接着,由于光伏逆变器需要产生220V的交流电给居民使用,因此…

iOS APP包分析工具 | 京东云技术团队

介绍 分享一款用于分析iOSipa包的脚本工具,使用此工具可以自动扫描发现可修复的包体积问题,同时可以生成包体积数据用于查看。这块工具我们团队内部已经使用很长一段时间,希望可以帮助到更多的开发同学更加效率的优化包体积问题。 工具下载…

EMG肌肉电信号处理合集(二)

本文主要展示常见的肌电信号特征的提取说明。使用python 环境下的Pysiology计算库。 目录 1 肌电信号第一次burst的振幅, getAFP 函数 2 肌电信号波长的标准差计算,getDASDV函数 3 肌电信号功率谱频率比例,getFR函数 4 肌电信号直方图…

深信服AF设置安全防护策略

以百度为例,禁止内网用户访问www.baidu.com 1、对象→安全策略模板→新增 2、名称自定义,安全配置只选择url过滤 3、点击图标→新增→设置名称及url 勾选刚刚新增的url--deny→确定 4、高级选项→确定 5、策略→安全策略→安全防护策略→新增用户防护策略…

宿主Linux——KVM安装Windows7系统

KVM虚拟技术 KVM(Kernel-based Virtual Machine) 是基于Linux内核的开源虚拟化技术,在一台物理机上可同时运行多个虚拟系统。KVM使用硬件虚拟化扩展,例如Intel的VT和AMD的AMD-V,在性能方面更加高效,可提供更好的计算能力和响应速…

WordPress用sql命令批量删除所有文章

有时我们需要将一个网站搬迁到另一个服务器。我们只想保留网站的模板样式,而不需要文章内容。一般情况下我们可以在后台删除已发表的文章,但如果有很多文章,我们则需要一次删除所有文章。 WordPress如何批量删除所有文章 进入网站空间后台&a…

GitHub上8个强烈推荐的 Python 项目

文章目录 前言1. Manim2. DeepFaceLab3. Airflow4. GPT-25. XSStrike6. 谷歌图片下载7. Gensim8. SocialMapper总结关于Python技术储备一、Python所有方向的学习路线二、Python基础学习视频三、精品Python学习书籍四、Python工具包项目源码合集①Python工具包②Python实战案例③…

Spring Boot集成MyBatis实现多数据源访问的“秘密”

文章目录 为什么需要多数据源?Spring Boot集成MyBatis的基础配置使用多数据源小结 🎉Spring Boot集成MyBatis实现多数据源访问的“秘密” ☆* o(≧▽≦)o *☆嗨~我是IT陈寒🍹✨博客主页:IT陈寒的博客🎈该系列文章专栏&…

51单片机应用从零开始(七)·循环语句(if语句,swtich语句)

51单片机应用从零开始(一)-CSDN博客 51单片机应用从零开始(二)-CSDN博客 51单片机应用从零开始(三)-CSDN博客 51单片机应用从零开始(四)-CSDN博客 51单片机应用从零开始(…

案例014:Java+SSM+uniapp+mysql基于微信小程序的健身管理系统

文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序…

人工智能对网络安全的影响越来越大

如果问当前IT行业最热门的话题是什么,很少有人会回答除了人工智能(AI)之外的任何话题。 在不到 12 个月的时间里,人工智能已经从一项只有 IT 专业人员才能理解的技术发展成为从小学生到作家、程序员和艺术家的每个人都使用的工具…

C++设计模式之工厂模式(中)——工厂模式

工厂模式 工厂模式介绍示例示例使用运行结果工厂模式与简单工厂模式区别 工厂模式 工厂模式在简单工厂模式的基础之上进行了改进。当需要生产的产品种类增加,可以通过新增子类工厂来生产,没有破坏程序设计原则中的开放封闭原则。 介绍 工厂模式先抽象…