aiohttp web服务端(server)样例 (非client)
python版本 python3.6 (其他版本需要小改,版本>python3.4)
参考网址:https://www.cnblogs.com/ameile/p/5589808.html asyncio创建协程解析——分析廖雪峰的Python教程之创建WEB服务
本实例接收 字符串类型值 ;
客户端发送过来的数据类型都是字符串,不能为二进制流(折衷方式可base64编码成字符串)。
import os
import re
import sys
import time
import json
import socket
import base64
import logging
import asyncio
import aiohttp
import datetime
from config import *
from aiohttp import web
from urllib.request import urlopen
from mlogging import TimedRotatingFileHandler_MP ip = str(sys.argv[2])
conn = aiohttp.TCPConnector(limit=1000)
session = aiohttp.ClientSession(connector=conn) log_name = os.path.join('./log','log_http.log')
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
fh = TimedRotatingFileHandler_MP('./log/log_http.log', 'D', 1, CYCLE_TIME)
fh.setFormatter(formatter)
log = logging.getLogger('http_recv')
log.setLevel(logging.DEBUG)
log.addHandler(fh) def b2base(b):
b = base64.b64encode(b)
b = str(b)
b = b[2:len(b)-1]
return b
async def downloadurl(dic):
try:
Prior = str(dic['Prior'])
FileId = str(dic['FileId'])
AppId = str(dic['AppID'])
except:
return 400
if len(Prior.strip()) == 0 or len(FileId.strip()) == 0 or len(AppId.strip()) == 0:
return 401
try:
if len(dic['FileUrl'].strip()) > 0 and len(dic['File'].strip()) > 0:
return 402
except:
pass
try:
if len(dic['FileUrl'].strip()) > 0:
try:
Resp = urlopen(dic['FileUrl'],timeout=5)
File = Resp.read()
except socket.timeout as e:
return 404
except:
return 403
except:
return 400
AppId = AppId + str(datetime.datetime.now().strftime('%Y-%m-%d'))
FileName = FileId + '_' + AppId + '_'
return FileName + b2base(File) async def deal_error(code):
if code == 400:
return json.dumps({ "code":400,"errMessage":"请求参数不正确." }, ensure_ascii=False).encode('utf-8')
elif code == 401:
return json.dumps({ "code":404,"errMessage":"图片下载超时." }, ensure_ascii=False).encode('utf-8')
elif code == 402:
return json.dumps({ "code":402,"errMessage":"同时传入了要求是二选一或者多选一的参数." }, ensure_ascii=False).encode('utf-8')
elif code == 403:
return json.dumps({ "code":403,"errMessage":"无法从指定的FileUrl下载图片,图片URL错误或者无效." }, ensure_ascii=False).encode('utf-8')
elif code == 404:
return json.dumps({ "code":404,"errMessage":"图片下载超时." }, ensure_ascii=False).encode('utf-8')
else:
return json.dumps({ "code":500,"errMessage":"其他错误." }, ensure_ascii=False).encode('utf-8') async def FileDealPost(request):
info = request.message
log.info("info_post = %s",info)
try:
info = await request.text()
log.info("info = %s",info)
reg = 'name="([a-zA-Z]*)".*?\r\n\r\n\W*(\S*)-*'
li = re.findall(reg,info,re.S)
dic = dict(li)
data_base64 = await downloadurl(dic)
except Exception as e:
log.info("error_post = %s",e)
if data_base64 in [400,401,402,403,404]:
result = await deal_error(data_base64)
return web.Response(body = result)
#async with session.post('http://'+ip+':1218/?name=ocr_image_indb&opt=put',data=data_base64,timeout = 0) as resp:
async with session.post('http://'+ip+':1218/?name=image&opt=put',data=data_base64,timeout = 0) as resp:
result = await resp.text()
if result == 'HTTPSQS_PUT_OK':
return web.Response(body = json.dumps({ "code":0,"errMessage":"成功" }, ensure_ascii=False).encode('utf-8'))
elif result == 'HTTPSQS_PUT_END':
return web.Response(body = json.dumps({ "code":-1,"errMessage":"请求已达上限,稍微再试." }, ensure_ascii=False).encode('utf-8'))
else:
return web.Response(body = json.dumps({ "code":-2,"errMessage":"入消息队列失败." }, ensure_ascii=False).encode('utf-8')) async def FileDealGet(request):
info = request.message
log.info("info_get = %s",info)
try:
info = request.message.path
reg = '[?&]([a-zA-Z]*)=([^&]*)'
li = re.findall(reg,info)
dic = dict(li)
data_base64 = await downloadurl(dic)
except Exception as e:
log.info("error_get = %s",e)
if data_base64 in [400,401,402,403,404]:
result = await deal_error(data_base64)
return web.Response(body = result)
#async with session.post('http://'+ip+':1218/?name=ocr_image_indb&opt=put',data=data_base64,timeout = 0) as resp:
async with session.post('http://'+ip+':1218/?name=image&opt=put',data=data_base64,timeout = 0) as resp:
result = await resp.text()
if result == 'HTTPSQS_PUT_OK':
return web.Response(body = json.dumps({ "code":0,"errMessage":"成功" }, ensure_ascii=False).encode('utf-8'))
elif result == 'HTTPSQS_PUT_END':
return web.Response(body = json.dumps({ "code":-1,"errMessage":"请求已达上限,稍微再试." }, ensure_ascii=False).encode('utf-8'))
else:
return web.Response(body = json.dumps({ "code":-2,"errMessage":"入消息队列失败." }, ensure_ascii=False).encode('utf-8')) async def init(loop):
app = web.Application(loop=loop)
app.router.add_route('POST', '/file', FileDealPost)
app.router.add_route('GET', '/file', FileDealGet)
srv = await loop.create_server(app.make_handler(),'10.10.11.32', int(sys.argv[1]))
return srv loop = asyncio.get_event_loop()
loop.run_until_complete(init(loop))
loop.run_forever()
aiohttp web服务端(server)样例 (非client)的更多相关文章
- Oracle Tuxedo工作站客户端与服务端的样例程序
服务端代码: #include <stdio.h> #include <stdlib.h> #include <string.h> #include <cty ...
- 关于如何提高Web服务端并发效率的异步编程技术
最近我研究技术的一个重点是java的多线程开发,在我早期学习java的时候,很多书上把java的多线程开发标榜为简单易用,这个简单易用是以C语言作为参照的,不过我也没有使用过C语言开发过多线程,我只知 ...
- 如何提高Web服务端并发效率的异步编程技术
作为一名web工程师都希望自己做的web应用能被越来越多的人使用,如果我们所做的web应用随着用户的增多而宕机了,那么越来越多的人就会变得越来越少了,为了让我们的web应用能有更多人使用,我们就得提升 ...
- Web服务端性能提升实践
随着互联网的不断发展,日常生活中越来越多的需求通过网络来实现,从衣食住行到金融教育,从口袋到身份,人们无时无刻不依赖着网络,而且越来越多的人通过网络来完成自己的需求. 作为直接面对来自客户请求的Web ...
- Delphi XE5通过WebService开发Web服务端和手机客户端
Delphi XE5通过WebService开发Web服务端和手机客户端介绍 我们开发一个三层的android程序 建立一个webservices stand-alone vcl applicati ...
- wsgiref手写一个web服务端
''' 通过wsgiref写一个web服务端先讲讲wsgiref吧,基于网络通信其根本就是基于socket,所以wsgiref同样也是通过对socket进行封装,避免写过多的代码,将一系列的操作封装成 ...
- winform客户端利用webClient实现与Web服务端的数据传输
由于项目需要,最近研究了下WebClient的数据传输.关于WebClient介绍网上有很多详细介绍,大概就是利用WebClient可以实现对Internet资源的访问.无外乎客户端发送请求,服务端处 ...
- web服务端的架构演变
此文已由作者肖凡授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 最近Lofter项目碰到很多性能上的问题,特别是数据库相关的,每次推送后,告警就会第一时间到来.这些问题随着产 ...
- Rsync同步部署web服务端配置
Rsync同步部署web服务端配置 1,参数详解: -v, --verbose 详细模式输出. -q, --quiet 精简输出模式. -c, --checksum 打开校验开关,强制对文件传输进行校 ...
随机推荐
- Perl 笔试题2 -- 统计单词频次
Nvidia 2019 perl 笔试题 统计一个文件内单词的频次并排序 文本如下: "ALL happy families resemble one another; every unha ...
- UVA - 818 Cutting Chains(切断圆环链)(dfs + 二进制法枚举子集)
题意:有n个圆环(n<=15),已知已经扣在一起的圆环,现在需要打开尽量少的圆环,使所有圆环可以组成一条链. 分析:因为不知道要打开哪个环,如果列举所有的可能性,即枚举打开环的所有子集,最多才2 ...
- UVA - 116 Unidirectional TSP (单向TSP)(dp---多段图的最短路)
题意:给一个m行n列(m<=10, n<=100)的整数矩阵,从第一列任何一个位置出发每次往右,右上或右下走一格,最终到达最后一列.要求经过的整数之和最小.第一行的上一行是最后一行,最后一 ...
- 小程序实现倒计时:解决ios倒计时失效(setInterval失效)
在使用之前需要先在page页引入wxTimer.js文件(这里我将文件放在/utils) let timer = require('../../utils/wxTimer.js'); 然后就可以使用啦 ...
- 51nod 1475:建设国家 优先队列的好题
1475 建设国家 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 收藏 关注 小C现在想建设一个国家.这个国家中有一个首都,然后有若干个中间站,还有若干个城市 ...
- POJ 2346:Lucky tickets
Lucky tickets Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3247 Accepted: 2136 Des ...
- MFC 实现CTreeCtrl单选
void CDepartmenManager::SetUncheck(HTREEITEM hTree) { if (!hTree){ return; } m_DePartmentView.SetChe ...
- js interval ,timeout
var inter; intervatest("2019-08-22 09:12:00"); function intervatest(str) { ShowCountDown(s ...
- 自学Java第五章——《面向对象基础》
5.1 类与对象 1.类:一类具有相同特性的事物的抽象描述. 对象:类的一个个体,实例,具体的存在. 类是对象的设计模板. 2.如何声明类? [修饰符] class 类名{ 成员列表:属性.方法 ...
- 二十七、CI框架之自己写分页类并加载(写分页还是有难度,搞了一整天)
一.我们写好自己的分页代码,防止library目录中,带构造函数 二.在模型中,添加2个函数,一个是查询数据的条数,第二个是取出数据库中的数据 三.在控制中,写入相应的代码,如下: 四.在界面中,写入 ...