python网络编程-socketserver模块
使用socketserver
- 老规矩,先引入
import socketserver - 必须创建一个类,且继承
socketserver.BaseRequestHandler - 这个类中必须重写
handle(self)函数负责和客户端进行交互,所以的交互都写这里面 - 可以重写的方法
#socketserver.BaseRequestHandler 类
def setup(self):#请求进来之前的操作
pass
def handle(self):#处理请求的操作
pass
def finish(self):#请求结束后的后事
pass
我的客户端和服务端例子
- 服务端
import socketserver
class MyTCPHandler(socketserver.BaseRequestHandler):
def handle(self):
#print(self.__dict__)#查看继承类中的属性和方法
#print(self.server.__dict__)#查看ThreadingTCPServer中的属性和方法
while True:
try:
data = self.request.recv(1024)
#self.request.recv
print('收到命令:', data.decode())
cmd = data.decode()
# if not data:#socket中判断客户端是否断开的方法
# print('客户端已断开')
# break
cmd_res = os.popen(cmd).read()
if len(cmd_res) == 0:
cmd_res = 'has not this command...'
# 先发送结果长度给客户端判断
res_size = len(cmd_res.encode())
self.request.send(str(res_size).encode('utf-8'))
client_ack = self.request.recv(1024) # 为防止粘包发生,这里给客户端在接收到数据大小后,发送一个消息给服务端确认
print(client_ack.decode())
self.request.send(cmd_res.encode('utf-8'))
except ConnectionResetError as e:#在socketserver模块中,捕获ConnectionResetError判断客户端是否断开
print('连接断开:',e)
break
if __name__ == "__main__":
HOST, PORT = "localhost", 6512
# Create the server, binding to localhost on port 9999
server = socketserver.ThreadingTCPServer((HOST, PORT), MyTCPHandler)#多线程
#server = socketserver.ForkingTCPServer((HOST, PORT), MyTCPHandler)#多进程,windows无法使用,linux适用
# Activate the server; this will keep running until you
# interrupt the program with Ctrl-C
server.serve_forever()
- 客户端
import socket
client = socket.socket()
client.connect(('localhost',6512))
while True:
cmd = input('>>:')
if len(cmd) == 0 : continue
client.send(cmd.encode('utf-8'))
cmd_res_size = client.recv(1024)#接收结果长度
client.send('数据大小已收到,准备接收数据'.encode('utf-8'))#告诉服务器可以发送数据结果
recv_size = 0
cmd_res = b''
while recv_size < int(cmd_res_size.decode()):
data = client.recv(1024)
recv_size += len(data)
cmd_res += data
else:
print(cmd_res.decode())
print('res is end...')
client.close()
父类socketserver.BaseRequestHandler中的__dict__
{
'request': <socket.socketfd=296,
family=AddressFamily.AF_INET,#地址簇
type=SocketKind.SOCK_STREAM,#socket类型
proto=0,
laddr=('127.0.0.1',
6512),#服务端地址和端口
raddr=('127.0.0.1',
53668)>,#客户端地址和端口
'client_address': ('127.0.0.1',
53668),#客户端地址和端口
'server': <socketserver.ThreadingTCPServerobjectat0x0000000001EC8AC8>
}
ThreadingTCPServer类中的__dict__
{
'server_address': ('127.0.0.1',
6512),
'RequestHandlerClass': <class'__main__.MyTCPHandler'>,
'_BaseServer__is_shut_down': <threading.Eventobjectat0x0000000001EC8940>,
'_BaseServer__shutdown_request': False,
'socket': <socket.socketfd=200,
family=AddressFamily.AF_INET,
type=SocketKind.SOCK_STREAM,
proto=0,
laddr=('127.0.0.1',
6512)>
}
RequestHandlerClass:
{
'__module__': '__main__',
'handle': <functionMyTCPHandler.handleat0x0000000001ED31E0>,#指向我们自己定义的类
'__doc__': None
}
_BaseServer__is_shut_down:
{
'_cond': <Condition(<unlocked_thread.lockobjectat0x0000000001E8D918>,
0)>,
'_flag': False
}
python网络编程-socketserver模块的更多相关文章
- python网络编程socketserver模块(实现TCP客户端/服务器)
摘录python核心编程 socketserver(python3.x版本重新命名)是标准库中的网络编程的高级模块.通过将创建网络客户端和服务器所必须的代码封装起来,简化了模板,为你提供了各种各样的类 ...
- python网络编程——SocketServer/Twisted/paramiko模块
在之前博客C/S架构的网络编程中,IO多路复用是将多个IO操作复用到1个服务端进程中进行处理,即无论有多少个客户端进行连接请求,服务端始终只有1个进程对客户端进行响应,这样的好处是节省了系统开销(se ...
- (网络编程)socketserver模块服务端实现并发
基于tcp的套接字(实现并发),关键就是两个循环,一个链接循环,一个通信循环 基于udp的套接字(不是正真意义上的并发,实现真并发) socketserver模块中分两大类:server类(解决链接问 ...
- python 网络编程--socket模块/struct模块
socket模块: 客户端:CS架构, client -> server 浏览器:BS架构, browser -> server 网络通信本质:传输字节 doc命令查看ip地址:ipc ...
- 网络编程------socketserver模块以及socket模块的更多用法.
socketserver模块 内置模块 (其实现原理为并发) socketserver这个模块主要是为了解决: TCP协议中,服务器不能同时连接多个客户端的问题 是处于socket抽象层和应用层之间的 ...
- python网络编程--socketserver 和 ftp功能简单说明
1. socketserver 我们之前写的tcp协议的socket是不是一次只能和一个客户端通信,如果用socketserver可以实现和多个客户端通信.它是在socket的基础上进行了一层封装,也 ...
- python网络编程-socketserver
一:socketserver简化了网络服务器的编写. 它有4个类:TCPServer,UDPServer,UnixStreamServer,UnixDatagramServer. 这4个类是同步进行处 ...
- python 网络编程(socketserver,阻塞,其他方法)
重点回顾: (重点)粘包 : 就是因为接收端不知道如何接收数据,造成接收数据的混乱的问题 只发生在tcp协议上. 因为tcp协议的特点是面向数据流形式的传输 粘包的发生主要是因为tcp协议有两个机制: ...
- python网络编程----requests模块
python访问网站可以用标准模块--urllib模块(这里省略),和requests(安装-pip install requests)模块,requests模块是在urllib的基础上进行的封装,比 ...
随机推荐
- 重装iTunes 错误代码42401 解决办法
昨晚手贱点击从iTunes 11升级到iTunes12,之后发现iTunes 12各种卡,简直不能忍,然后直接拉iTunes 12到AppClear,然后安装iTunes 11,安装完成之后打开iTu ...
- UESTC 趣味赛命题报告E
https://lutece.xyz/contest/detail/10/ 题目很简单,套路题: 求n个数中选k个数使得gcd最大: 很容易想到,我们只需要将因子分解出来然后计数即可: (只是这个id ...
- 【模板】文艺平衡树(Splay) 区间翻转 BZOJ 3223
您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 4 1 N,M<= ...
- 再谈hive-1.0.0与hive-1.2.1到JDBC编程忽略细节问题
不多说,直接上干货,这个问题一直迷惑已久,今天得到亲身醒悟. 所以,建议hadoop-2.6.0.tar.gz的用户与hive-1.0.0搭配使用.当然,也可以去用高版本去覆盖它. log4j:WAR ...
- Centos6.8 yum安装LNMP
1.Centos6系统库中默认是没有nginx的rpn包的,所以我们需要先更新下rpm依赖库 (1):使用yum安装nginx,安装nginx库 rpm -Uvh http://nginx.org/p ...
- Oracle 11G R2在用EXP 导出时,空表不能导出解决办法
11G中有个新特性,当表无数据时,不分配segment,以节省空间 解决方法: 1.insert一行,再rollback就产生segment了. 该方法是在在空表中插入数据,再删除,则产生segmen ...
- eclipse gradle 找不到依赖解决办法
右击工程,选择gradle 在点击Refresh Gradle Project 即可,..不得不说,gradle 在eclipse 下真没maven 好用.....
- C++_静态类成员
在C++中,静态成员是属于整个类的而不是某个对象. 静态成员变量只存储一份供所有对象共用,所以在所有对象中都可以共享它. 使用静态成员变量实现多个对象之间的数据共享不会破坏隐藏的原则,保证了安全性还可 ...
- vue.js请求数据(axios)
使用npm安装axios npm install axios --save 在main.js中引入axios import axios from "axios"; 注册axios到 ...
- 18-----BBS论坛
BBS论坛(十八) 18.首页轮播图实现 (1)front/css/front_base.css .main-container{ width: 990px; margin: 0 auto; over ...