Flask Rest接口
Flask适用于简单的接口请求
安装
pip install Flask
pip install Flask-RESTful
仅简单请求url,然后出发处理程序,返回处理结果
app.py代码如下
from flask import Flask,jsonify
from flask_restful import Api,Resource,request,reqparse
from sqlalchemy import create_engine
from local_settings import SQLALCHEM
import logging,datetime
logger=logging.getLogger('my_app')
app=Flask(__name__)
api=Api(app)
class ProceListAPI(Resource):
def __init__(self):
self.engine=create_engine(alchemy_conf,pool_size=5,max_overflow=0,pool_recycle=7*60) # 初始化全局的数据库连接池
self.reqparse=reqparse.RequestParser()
self.reqparse.add_argument('subid',action='append',dest='cart_code',type=int,required=True,help='subid is needed!',location='form')
self.reqparse.add_argument('description',type=str,default="",location='json') # 配置 哪些入参是什么格式,在什么位置,dest表示别名
supper(PriceListAPI,self).__init__()
def get(self): #flask的api类中的所有get请求经过 get方法 ,post请求 经过post方法
logger.warning('request form:{},num:{}'.format(request.args,type(request.args.get('subid'))))
cart_code = request.args.get('subid')
if not cart_code:
return {'error':'subid is Rquired!'}
cart_code=cart_code.split(',')
with self.engine.connect() as conn:
result = conn.execute('select distinct cart_code,price from price_store where collect_time>=curdate();')
datas=result.fetchall()
dup_dict={}
for d in datas:
if d[0] in cart_code:
dup_dict[d[0]]=(d[0],d[1])
return dup_dict
def post(self):
args=self.reqparse.parse_args()
cart_code=args['cart_code']
if not cart_code:
return {'error':'subid is Required!'}
return {'cart_code':cart_code}
api.add_resource(PriceListAPI,'./price/',endpoint='stores') #定义class类 对应的url
if __name__ == '__main__':
app.run(debug=True,port=5091,houst='0.0.0.0')
通过 python app.py就可以运行
给API class添加装饰器 ,在每次请求处理前先进行验证 ,如常用的验证 Headers中的Authorization字段
将app_key和app_secret融合 加密到组成 Authorization的值,来判断用户是否为合法用户
首先需要定义一个装饰器函数
from functools import wraps
def my_authenticate(func):
@wraps(func)
def wrapper(*args,**kwargs):
authen = request.headers.get('Authorization')
if not authen:
return {"code":403,"message":"Authenticated Error","data":{"isEnabled":0}},403
logger.warning('authen:%s'%(authen))
encode_authen=authen.encode('utf-8')
decode_authen = base64.b64decode(encode_authen)
app_key,app_sign,timestamp = decode_authen.decode('utf-8').split(';')
now = time.time()
if now-float(timestamp)>2*60:
return {"code":403,"message":"Authenticated expired","data":{"isEnabled":0}},403
if app_key != APP_KEY:
return {"code":403,"message":"Authenticate app_key error","data":{"isEnabled":0}},403
md5_obj = hashlib.md5()
content = app_key+APP_SECRET+timestamp
md5_obj.update(content.encode('utf-8'))
my_sign=md5_obj.hexdigest()
if app_sign==my_sign:
logger.info("authen ok!")
return func(*args,**kwargs)
return {"code":403,"message":"Authenticated Error","data":{"isEnabled":0}},403
return wrapper
然后在class ProceListAPI(Resource)的开头加上 decorators=[my_authenticate]
如:
class ProceListAPI(Resource):
decorators=[my_authenticate]
def __init__(self):
self.reqparse=reqparse.RequestParser()
....
这样就相当于给类ProceListAPI的每个方法都加上了装饰器 my_authenticate
Flask Rest接口的更多相关文章
- Flask request接口获取参数
Flask request接口获取参数 request.form.get("key", type=str, default=None) 获取表单数据, request.args ...
- python——flask常见接口开发(简单案例)
python——flask常见接口开发(简单案例)原创 大蛇王 发布于2019-01-24 11:34:06 阅读数 5208 收藏展开 版本:python3.5+ 模块:flask 目标:开发一个只 ...
- Python直接改变实例化对象的列表属性的值 导致在flask中接口多次请求报错
错误原理实例如下: class One(): list = [1, 2, 3] @classmethod def get_copy_list(cls): # copy一份list,这样对list的改变 ...
- Python flask模块接口开发学习总结
引言 Flask 是一个简单且十分强大的Python web 框架.它被称为微框架,“微”并不是意味着把整个Web应用放入到一个Python文件,微框架中的“微”是指Flask旨在保持代码简洁且易于扩 ...
- Keras + Flask 提供接口服务的坑~~~
最近在搞Keras,训练完的模型要提供个预测服务出来.就想了个办法,通过Flask提供一个http服务,后来发现也能正常跑,但是每次预测都需要加载模型,效率非常低. 然后就把模型加载到全局,每次要用的 ...
- pyhton【flask接口开发】
使用flask进行接口开发 语言:Python3 框架:flask 在进行开发前首先得安装flask,然后才能使用.安装可以直接使用pip命令进行安装:pip install flask. 使用fla ...
- 使用Flask开发简单接口
作为测试人员,在工作或者学习的过程中,有时会没有可以调用的现成的接口,导致我们的代码没法调试跑通的情况. 这时,我们使用python中的web框架Flask就可以很方便的编写简单的接口,用于调用或调试 ...
- Flask备注三(Context)
Flask备注三(Context) Flask支持不同的应用场景下,对应不同的local context(本地上下文环境),用来提供当前环境下的资源.lcoal context和全局变量以及局部变量最 ...
- python框架(flask/django/tornado)比较
一.对外数据接口 三者作为web框架,都是通过url映射对外的接口 flask:以decorator的形式,映射到函数中 django:以字典形式,映射到函数 tornado: 以字典形式,映射到类中 ...
随机推荐
- k8s kubernetes 核心笔记 镜像仓库 项目k8s改造(含最新k8s v1.16.2版本)
k8s kubernetes 核心笔记 镜像仓库 项目k8s改造 2019/10/24 Chenxin 一 基本资料 一 参考: https://kubernetes.io/ 官网 https://k ...
- MySQL基础之练习题
题目 现有班级.学生以及成绩三张表: 备注:表名称和字段名称可以参考表格内单词设置 根据表格信息,按要求完成下面SQL语句的编写: 1.使用SQL分别创建班级表.学生表以及成绩表的表结构,表内数据可以 ...
- Good start is a half success(2019-04-07)
一. 回顾你过去将近3年的学习经历. (1)当初你报考的时候,是真正喜欢计算机这个专业吗?. (2)你现在后悔选择了这个专业吗?. (3)你认为你现在最喜欢的领域是什么(可以是计算机的也可以是其它领域 ...
- Ubuntu16.04 安装 JDK
1.到Oracle官网下载 地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html ...
- Codeforces Round #601 (Div. 2)
传送门 A. Changing Volume 签到. Code /* * Author: heyuhhh * Created Time: 2019/11/19 22:37:33 */ #include ...
- Java并发编程:Java实现多线程的几种方式
在Java中,多线程主要的实现方式有四种:继承Thread类.实现Runnable接口.实现Callable接口通过FutureTask包装器来创建Thread线程.使用ExecutorService ...
- dicom(dcm)文件批量Study Instance UID打包整理工具
一款可以自动识别原始dicom文件Study Instance UID的工具. 如果你有一堆混乱不堪的dcm文件,这个小工具能帮助你将这些无序的dicom文件按照Study Instance UID压 ...
- springboot mail整合freemark实现动态生成模板
目标:1:springboot 整合 mail2: mail 使用freemark 实现模板动态生成(就是通过字符串生成模板,不需要在工程中写入固定模板)3: springboot 整合aop 实现日 ...
- 巧妙利用selenium中的JS操作来处理特殊的文本框
在使用selenium对页面进行相关操作时,有时候会遇到以下三种情况: 1.日期框:无法直接输入文本,必须要选择某一天的日期并点击才会填入文本框: 2.检索框:可以直接输入文本,但必须要点击根据输入的 ...
- Rust对协程的思考
最近和同事聊起来,觉得lua缺乏编译型语言的类型校验功能,还有变量拼写检查之类的,导致线上总是有低级错误出现.比如最近有一个是变量名拼写少了一个字母,导致某功能没开启:还有一个是变量传参时,之前测试多 ...