Python网络编程——TCP服务端程序开发

简介: TCP服务端,需要与客户端建立连接,接收并处理客户端传输来的数据。

概述

TCP服务端,需要与客户端建立连接,接收并处理客户端传输来的数据。



实现步骤

1.导入socket包

importsocket


2.创建服务端套接字

socket.socket(AddressFamily, Type)

socket.AF_INET表示IPv4类型

SOCK_STREAM表示tcp

tcp_server_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
#端口复用 服务端退出端口立即释放tcp_server_socket.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,True)        


3.绑定端口号

tcp_server_socket.bind

第一个参数表示ip地址,一般不用指定 表示本机的任何一个ip

第二个参数表示端口号

tcp_server_socket.bind(('',9090))


4.设置监听

表示最大等待建立链接的个数128

tcp_server_socket.listen(128)


5.等待客户端的连接请求

new_client , ip_port=tcp_server_socket.accept()
print("客户端的ip和端口号是:" , ip_port)


6.接收数据

收发消息使用新返回的套接字

#每次接收1024字节rece_data=new_client.recv(1024)
#对接收到的二进制解码rece_data=rece_data.decode('utf-8')
print("接收到的数据是",rece_data)


7.发送数据

send_content="问题正在处理中"#对content进行编码send_data=send_content.encode('utf-8')
#发送数据new_client.send(send_data)
new_client.close()


8.关闭套接字

tcp_server_socket.close()


代码实现

#  tcp服务端程序开发importsocketif__name__=='__main__':
# 1.创建服务端套接字# socket.AF_INET表示IPv4类型# SOCK_STREAM表示tcptcp_server_socket=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
tcp_server_socket.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,True)
#端口复用 服务端退出端口立即释放#socket.SOL_SOCKET 表示当前套接字#socket.SO_REUSEADDR 复用选项#True 确定复用# 2.绑定端口号# 第一个参数表示ip地址,一般不用指定 表示本机的任何一个ip#第二个参数表示端口号tcp_server_socket.bind(('',9090))
# 3.设置监听# 128:表示最大等待建立链接的个数tcp_server_socket.listen(128)
# 4.等待客户端的连接请求#每次客户端和服务器建立连接成功都会返回一个新的套接字new_client , ip_port=tcp_server_socket.accept()
print("客户端的ip和端口号是:" , ip_port)
# 5.接收数据#收发消息使用新返回的套接字rece_data=new_client.recv(1024)
rece_data=rece_data.decode('utf-8')
print("接收到的数据是",rece_data)
# 6.发送数据send_content="问题正在处理中"send_data=send_content.encode('utf-8')
new_client.send(send_data)
new_client.close()
# 7.关闭套接字tcp_server_socket.close()
目录
相关文章
|
1月前
|
搜索推荐 程序员 调度
精通Python异步编程:利用Asyncio与Aiohttp构建高效网络应用
【10月更文挑战第5天】随着互联网技术的快速发展,用户对于网络应用的响应速度和服务质量提出了越来越高的要求。为了构建能够处理高并发请求、提供快速响应时间的应用程序,开发者们需要掌握高效的编程技术和框架。在Python语言中,`asyncio` 和 `aiohttp` 是两个非常强大的库,它们可以帮助我们编写出既简洁又高效的异步网络应用。
119 1
|
9天前
|
Python
Python中的异步编程:使用asyncio和aiohttp实现高效网络请求
【10月更文挑战第34天】在Python的世界里,异步编程是提高效率的利器。本文将带你了解如何使用asyncio和aiohttp库来编写高效的网络请求代码。我们将通过一个简单的示例来展示如何利用这些工具来并发地处理多个网络请求,从而提高程序的整体性能。准备好让你的Python代码飞起来吧!
25 2
|
16天前
|
数据采集 存储 JSON
Python网络爬虫:Scrapy框架的实战应用与技巧分享
【10月更文挑战第27天】本文介绍了Python网络爬虫Scrapy框架的实战应用与技巧。首先讲解了如何创建Scrapy项目、定义爬虫、处理JSON响应、设置User-Agent和代理,以及存储爬取的数据。通过具体示例,帮助读者掌握Scrapy的核心功能和使用方法,提升数据采集效率。
60 6
|
15天前
|
网络协议 安全 Go
Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
【10月更文挑战第28天】Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
43 13
|
4天前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
垃圾识别分类系统。本系统采用Python作为主要编程语言,通过收集了5种常见的垃圾数据集('塑料', '玻璃', '纸张', '纸板', '金属'),然后基于TensorFlow搭建卷积神经网络算法模型,通过对图像数据集进行多轮迭代训练,最后得到一个识别精度较高的模型文件。然后使用Django搭建Web网页端可视化操作界面,实现用户在网页端上传一张垃圾图片识别其名称。
25 0
基于Python深度学习的【垃圾识别系统】实现~TensorFlow+人工智能+算法网络
|
9天前
|
机器学习/深度学习 TensorFlow 算法框架/工具
利用Python和TensorFlow构建简单神经网络进行图像分类
利用Python和TensorFlow构建简单神经网络进行图像分类
28 3
|
14天前
|
数据采集 存储 XML
Python实现网络爬虫自动化:从基础到实践
本文将介绍如何使用Python编写网络爬虫,从最基础的请求与解析,到自动化爬取并处理复杂数据。我们将通过实例展示如何抓取网页内容、解析数据、处理图片文件等常用爬虫任务。
|
17天前
|
数据采集 前端开发 中间件
Python网络爬虫:Scrapy框架的实战应用与技巧分享
【10月更文挑战第26天】Python是一种强大的编程语言,在数据抓取和网络爬虫领域应用广泛。Scrapy作为高效灵活的爬虫框架,为开发者提供了强大的工具集。本文通过实战案例,详细解析Scrapy框架的应用与技巧,并附上示例代码。文章介绍了Scrapy的基本概念、创建项目、编写简单爬虫、高级特性和技巧等内容。
39 4
|
16天前
|
网络协议 算法 网络性能优化
计算机网络常见面试题(一):TCP/IP五层模型、TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议
计算机网络常见面试题(一):TCP/IP五层模型、应用层常见的协议、TCP与UDP的区别,TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议、ARP协议
|
23天前
|
Web App开发 缓存 网络协议
不为人知的网络编程(十八):UDP比TCP高效?还真不一定!
熟悉网络编程的(尤其搞实时音视频聊天技术的)同学们都有个约定俗成的主观论调,一提起UDP和TCP,马上想到的是UDP没有TCP可靠,但UDP肯定比TCP高效。说到UDP比TCP高效,理由是什么呢?事实真是这样吗?跟着本文咱们一探究竟!
49 10