TCP服务端
在程序中,如果想要完成一个TCP服务器的功能,需要按照以下流程进行操作:
- 创建套接字socket
- 绑定(IP和端口)
- 监听使套接字变为可被动连接
- 等待客户端的连接请求accept
- 接收/发送数据
- 关闭套接字
示例代码:
from socket import *
# 创建socket
tcp_server_socket = socket(AF_INET, SOCK_STREAM)
# 本地信息
address = ('', 7788)
# 绑定
tcp_server_socket.bind(address)
# 使用socket创建的套接字默认是主动的,使用listen将其变为被动的,这样就可以接收其他客户端的连接了
tcp_server_socket.listen(128)
# 如果有新的客户端来连接服务器,则产生一个新的套接字专门为这个客户端服务
# client_socket用来为这个客户端提供服务,而tcp_server_socket则可以继续等待其他新客户端的连接
client_socket, client_addr = tcp_server_socket.accept()
# 接收对方发送过来的数据
recv_data = client_socket.recv(1024) # 接收1024个字节
print('接收到的数据为:', recv_data.decode('gbk'))
# 发送一些数据到客户端
client_socket.send("thank you !".encode('gbk'))
# 关闭为这个客户端服务的套接字,只要关闭了,就不能再为这个客户端服务
# 如果还需要服务,只能重新连接
client_socket.close()
TCP注意事项
- TCP服务器一般需要进行绑定,否则客户端无法找到该服务器。
- TCP客户端一般不需要绑定,因为它是主动连接服务器的,只要确定了服务器的IP和端口等信息即可,而本地客户端可以随机选择。
- TCP服务器通过listen可以将socket创建出来的主动套接字变为被动套接字,这是编写TCP服务器时必须的操作。
- 当客户端需要连接服务器时,需要使用connect进行连接。与UDP不同,TCP必须先建立连接才能通信。
- 当一个TCP客户端连接到服务器时,服务器端会创建一个新的套接字,用于标识该客户端,并为该客户端提供服务。
- listen之后的套接字是被动套接字,用于接受新客户端的连接请求,而accept返回的新套接字则用于标识这个新客户端。
- 关闭listen之后的套接字意味着被动套接字关闭了,此时新的客户端将无法连接到服务器,但之前已经连接成功的客户端依然可以正常通信。
- 关闭accept返回的套接字意味着该客户端已经完成服务。
- 当客户端的套接字调用close后,服务器端的recv方法将解阻塞,并返回长度为0的数据,因此服务器可以通过返回的数据长度来区分客户端是否已经下线。
进阶案例
【Python】Python 实现猜单词游戏——挑战你的智力和运气!
【python】Python tkinter库实现重量单位转换器的GUI程序
【python】使用Selenium获取(2023博客之星)的参赛文章
【python】使用Selenium和Chrome WebDriver来获取 【腾讯云 Cloud Studio 实战训练营】中的文章信息
使用腾讯云 Cloud studio 实现调度百度AI实现文字识别
【玩转Python系列【小白必看】Python多线程爬虫:下载表情包网站的图片
【玩转Python系列】【小白必看】使用Python爬取双色球历史数据并可视化分析
【玩转python系列】【小白必看】使用Python爬虫技术获取代理IP并保存到文件中
【小白必看】Python图片合成示例之使用PIL库实现多张图片按行列合成
【小白必看】Python爬虫实战之批量下载女神图片并保存到本地
【小白必看】使用Python爬取喜马拉雅音频并保存的示例代码
【小白必看】使用Python批量下载英雄联盟皮肤图片的技术实现
【小白必看】轻松获取王者荣耀英雄皮肤图片的Python爬虫程序
【小白必看】Python爬虫实战:获取阴阳师网站图片并自动保存
小白实战100案例: 完整简单的双色球彩票中奖判断程序,适合小白入门
使用 geopandas 和 shapely(.shp) 进行地理空间数据处理和可视化
爬虫入门指南(7):使用Selenium和BeautifulSoup爬取豆瓣电影Top250实例讲解【爬虫小白必看】
爬虫入门指南(6):反爬虫与高级技巧:IP代理、User-Agent伪装、Cookie绕过登录验证及验证码识别工具
爬虫入门指南(5): 分布式爬虫与并发控制 【提高爬取效率与请求合理性控制的实现方法】
爬虫入门指南(4): 使用Selenium和API爬取动态网页的最佳方法
爬虫入门指南(3):Python网络请求及常见反爬虫策略应对方法
深度学习模型在图像识别中的应用:CIFAR-10数据集实践与准确率分析
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
使用Python和Selenium自动化爬取 #【端午特别征文】 探索技术极致,未来因你出“粽” # 的投稿文章
Python多线程与多进程教程:全面解析、代码案例与优化技巧
Python入门教程:掌握for循环、while循环、字符串操作、文件读写与异常处理等基础知识