首页 » Web前端 » phpsocketafinet技巧_python运用SocketServer实现收集做事器

phpsocketafinet技巧_python运用SocketServer实现收集做事器

访客 2024-11-17 0

扫一扫用手机浏览

文章目录 [+]

SocketServer简化了网络做事器的编写。
在进行socket创建时,利用SocketServer会大大减少创建的步骤,并且SocketServer利用了select它有4个类:TCPServer,UDPServer,UnixStreamServer,UnixDatagramServer。
这4个类是同步进行处理的,其余通过ForkingMixIn和ThreadingMixIn类来支持异步。

利用SocketServer的步骤简介

phpsocketafinet技巧_python运用SocketServer实现收集做事器

创建做事器的步骤。
首先,你必须创建一个要求处理类,它是BaseRequestHandler的子类并重载其handle()方法。

phpsocketafinet技巧_python运用SocketServer实现收集做事器
(图片来自网络侵删)

实例化一个做事器类,传入做事器的地址和要求处理程序类。

末了,调用handlerequest()(一样平常是调用其他事宜循环或者利用select())或serveforever()。

集成ThreadingMixIn类时须要处理非常关闭。
daemon_threads指示做事器是否要等待线程终止,假如线程相互独立,必须要设置为True,默认是False。

无论用什么网络协议,做事器类有相同的外部方法和属性。

测试案例

做事器端为一个韶光戳做事器,在吸收到客户端发来的数据后,自动回答。

客户端,等待用户输入,回车后向做事器发送用户输入的内容。

分别在python2.7和python3.6下测试。
在启动时须要先启动做事器端,在启动客户端。

python2.7下

做事器端代码为

#coding:utf-8import SocketServerfrom time import ctimeprint(\"大众=====================SocketServer TCP做事器=====================\公众);HOST = '' #主机号为空缺表示可以利用任何可用的地址。
PORT = 21567 #端口号ADDR = (HOST, PORT)class MyRequestHandler(SocketServer.StreamRequestHandler): #StreamRequestHandler实现TCP/UDP做事器的做事处理器 def handle(self): #重写吸收相应函数 print('...connect from:', self.client_address) data = self.rfile.readline().strip() print(data) self.wfile.write('[%s] %s' % (ctime(), data))tcpSerSock = SocketServer.TCPServer(ADDR, MyRequestHandler)print('等待连接...')tcpSerSock.serve_forever()

客户端代码为

#coding:utf-8from socket import print(\"大众=====================SocketServer TCP客户端=====================\公众);HOST = '127.0.0.1' #本机测试PORT = 21567BUFSIZ = 1024ADDR = (HOST, PORT)while True: tcpCliSock = socket(AF_INET, SOCK_STREAM) #创建客户端套接字 tcpCliSock.connect(ADDR) #发起TCP连接 data = raw_input('> ') #吸收用户输入 if not data: #如果用户输入为空,直接回车就会发送\"大众\公众,\公众\"大众便是代表false break tcpCliSock.send(data+'\n') #客户端发送,必须发送字节数组 data = tcpCliSock.recv(BUFSIZ) #吸收回应,吸收到的是字节数组 if not data: #如果吸收做事器信息失落败,或相应为空 break print(data) #打印回应 tcpCliSock.close() #关闭客户端socket

python3.6下

SocketServer模块在python3中已经更名为socketserver。

做事器端代码为

#coding:utf-8import socketserverfrom time import ctimeprint(\公众=====================SocketServer TCP做事器=====================\公众);HOST = '' #主机号为空缺表示可以利用任何可用的地址。
PORT = 21567 #端口号ADDR = (HOST, PORT)class MyRequestHandler(socketserver.StreamRequestHandler): #StreamRequestHandler实现TCP/UDP做事器的做事处理器 def handle(self): #重写吸收相应函数 print('连接到:', self.client_address) data = self.rfile.readline().strip() print(data) self.wfile.write(bytes('[%s] %s' % (ctime(), data.decode('utf-8')),'utf-8'))tcpSerSock = socketserver.TCPServer(ADDR, MyRequestHandler)print('等待连接...')tcpSerSock.serve_forever()

客户端代码为

#coding:utf-8from socket import print(\"大众=====================SocketServer TCP客户端=====================\公众);HOST = '127.0.0.1' #本机测试PORT = 21567BUFSIZ = 1024ADDR = (HOST, PORT)while True: tcpCliSock = socket(AF_INET, SOCK_STREAM) #创建客户端套接字 tcpCliSock.connect(ADDR) #发起TCP连接 data = input('> ') #吸收用户输入 if not data: #如果用户输入为空,直接回车就会发送\"大众\公众,\"大众\公众便是代表false break tcpCliSock.send(bytes(data+'\n','utf-8')) #客户端发送,必须发送字节数组 buffer = tcpCliSock.recv(BUFSIZ) #吸收回应,吸收到的是字节数组 if not buffer: #如果吸收做事器信息失落败,或相应为空 break print(str(buffer,'utf-8')) #打印回应 tcpCliSock.close() #关闭客户端socket做事器类型

5种类型:BaseServer,TCPServer,UnixStreamServer,UDPServer,UnixDatagramServer。
把稳:BaseServer不直接对外做事。

做事器工具

•class SocketServer.BaseServer:这是模块中的所有做事器工具的超类。
它定义了接口,如下所述,但是大多数的方法不实现,在子类中进行细化。

•BaseServer.fileno():返回做事器监听套接字的整数文件描述符。
常日用来通报给select.select(), 以许可一个进程监视多个做事器。

•BaseServer.handlerequest():处理单个要求。
处理顺序:getrequest(), verifyrequest(), processrequest()。
如果用户供应handle()方法抛出非常,将调用做事器的handleerror()方法。
如果self.timeout内没有要求收到, 将调用handletimeout()并返回handle_request()。

•BaseServer.serveforever(pollinterval=0.5): 处理要求,直到一个明确的shutdown()要求。
每poll_interval秒轮询一次shutdown。
忽略self.timeout。
如果你须要做周期性的任务,建议放置在其他线程。

•BaseServer.shutdown():见告serve_forever()循环停滞并等待其停滞。
python2.6版本。

•BaseServer.addressfamily: 地址家族,比如socket.AFINET和socket.AF_UNIX。

•BaseServer.RequestHandlerClass:用户供应的要求处理类,这个类为每个要求创建实例。

•BaseServer.server_address:做事器侦听的地址。
格式根据协议家族地址的各不相同,请参阅socket模块的文档。

•BaseServer.socketSocket:做事器上侦听传入的要求socket工具的做事器。

做事器类支持下面的类变量:

•BaseServer.allowreuseaddress:做事器是否许可地址的重用。
默认为false ,并且可在子类中变动。

•BaseServer.requestqueuesize

要求行列步队的大小。
如果单个要求须要很长的韶光来处理,做事器忙时要求被放置到行列步队中,最多可以放requestqueuesize个。
一旦行列步队已满,来自客户真个要求将得到 “Connection denied”缺点。
默认值常日为5 ,但可以被子类覆盖。

•BaseServer.sockettype:做事器利用的套接字类型; socket.SOCKSTREAM和socket.SOCK_DGRAM等。

•BaseServer.timeout:超时时间,以秒为单位,或 None表示没有超时。
如果handlerequest()在timeout内没有收到要求,将调用handletimeout()。

下面方法可以被子类重载,它们对做事器工具的外部用户没有影响。

•BaseServer.finish_request():实际处理RequestHandlerClass发起的要求并调用其handle()方法。
常用。

•BaseServer.get_request():接管socket要求,并返回二元组包含要用于与客户端通信的新socket工具,以及客户真个地址。

•BaseServer.handleerror(request, clientaddress):如果RequestHandlerClass的handle()方法抛出非常时调用。
默认操作是打印traceback到标准输出,并连续处理其他要求。

•BaseServer.handle_timeout():超时处理。
默认对付forking做事器是网络退出的子进程状态,threading做事器则什么都不做。

•BaseServer.processrequest(request, clientaddress) :调用finish_request()创建RequestHandlerClass的实例。
如果须要,此功能可以创建新的进程或线程来处理要求,ForkingMixIn和ThreadingMixIn类做到这点。
常用。

•BaseServer.server_activate():通过做事器的布局函数来激活做事器。
默认的行为只是监听做事器套接字。
可重载。

•BaseServer.server_bind():通过做事器的布局函数中调用绑定socket到所需的地址。
可重载。

•BaseServer.verifyrequest(request, clientaddress):返回一个布尔值,如果该值为True ,则该要求将被处理,反之要求将被谢绝。
此功能可以重写来实现对做事器的访问掌握。
默认的实现始终返回True。
client_address可以限定客户端,比如只处理指定ip区间的要求。
常用。

要求处理器

处理器吸收数据并决定如何操作。
它卖力在socket层之上实现协议(i.e., HTTP, XML-RPC, or AMQP),读取数据,处理并写反应。
可以重载的方法如下:

•setup(): 准备要求处理. 默认什么都不做,StreamRequestHandler中会创建文件类似的工具以读写socket.

•handle(): 处理要求。
解析传入的要求,处理数据,并发送相应。
默认什么都不做。
常用变量:self.request,self.client_address,self.server。

•finish(): 环境清理。
默认什么都不做,如果setup产生非常,不会实行finish。

常日只须要重载handle。
self.request的类型和数据报或流的做事不同。
对付流做事,self.request是socket 工具;对付数据报做事,self.request是字符串和socket 。
可以在子类StreamRequestHandler或DatagramRequestHandler中重载,重写setup()和finish() ,并供应self.rfile和self.wfile属性。
self.rfile和self.wfile可以读取或写入,以得到要求数据或将数据返回到客户端。

末了,我自己是一名从事了多年开拓的Python老程序员,辞职目前在做自己的Python私人定制课程,今年年初我花了一个月整理了一份最适宜2019年学习的Python学习干货,可以送给每一位喜好Python的小伙伴,想要获取的可以关注我的头条号并在后台私信我:01,即可免费获取。

相关文章

青海,西部IT产业的璀璨明珠

近年来,随着互联网、大数据、人工智能等新兴技术的快速发展,我国西部地区的IT产业逐渐崭露头角。青海省作为我国西部地区的代表,凭借其...

Web前端 2024-12-26 阅读0 评论0

E语言工具箱,助力编程学习的得力助手

在信息技术飞速发展的时代,编程已成为一项必备技能。而E语言工具箱作为一款功能强大的编程辅助工具,为广大学子提供了便捷的学习路径。本...

Web前端 2024-12-26 阅读0 评论0

餐饮IT部门在智慧餐饮建设中的关键作用

随着我国经济的快速发展,餐饮行业作为服务业的重要组成部分,逐渐成为国民经济的重要支柱。在互联网、大数据、人工智能等新兴技术的推动下...

Web前端 2024-12-26 阅读0 评论0

DIY设计墙,打造个性化家居空间的创意之旅

随着人们生活水平的提高,家居环境已成为衡量生活质量的重要标准。在这个追求个性化、时尚的时代,DIY设计墙应运而生,成为了家居装饰的...

Web前端 2024-12-26 阅读0 评论0