flask-restful使用总结
flask-restful是一个用于快速创建restful api接口的flask扩展。使用flask-restful可以很快速方便地创建一个restful风格的接口应用程序。
1、安装
pip install flask_restful
2、全部代码
from flask import flask from flask_restful import reqparse, abort, api, resource app = flask(__name__) api = api(app) todos = { 'todo1': {'task': 'build'}, 'todo2': {'task': 'bui2'}, 'todo3': {'task': 'bui3'} } parser = reqparse.requestparser() parser.add_argument('task') class todo(resource): def get(self, todo_id): return todos[todo_id] def delete(self, todo_id): del todos[todo_id] return '', 204 def put(self, todo_id): args = parser.parse_args() task = {'task': args['task']} todos[todo_id] = task return task, 201 class todolist(resource): def get(self): return todos api.add_resource(todolist, '/todos') api.add_resource(todo, '/todos/<todo_id>') if __name__ == '__main__': app.run(debug=true)
3、代码说明
1). 初始化
在当前程序初始化一个flask-restful的api实例:
api = api(app)
2). 定义资源类
资源类是restful接口的具体实现,需要继承resource类。在类中可以定义get、post等符合restful规范的接口。
class todo(resource): def get(self, todo_id): return todos[todo_id] def delete(self, todo_id): del todos[todo_id] return '', 204 def put(self, todo_id): args = parser.parse_args() task = {'task': args['task']} todos[todo_id] = task return task, 201
3). 参数解析
虽然 flask 提供了简单的方法访问请求数据, 但是对于表单数据处理还是比较麻烦. flask-restful 提供了 reqparse 一种类似 argparse 参数解析机制以简化参数处理.
parser = reqparse.requestparser(): reqparse使用requestparser() 可以从 flask.request.values,以及 flask.request.json 解析值。这里创建了一个解析对象parser。
parser.add_argument('task'):向parser对象中添加你要关注的命令行参数和选项,每一个add_argument方法对应一个你要关注的参数或选项。
parser.parse_args():调用parse_args()方法进行解析,解析成功之后即可使用。
4). add_argument扩展
对于必传的参数,可以设置required=true
parser.add_argument('name', type=str, required=true, help="name cannot be blank!")
传多个值,使用 action='append'
parser.add_argument('name', type=str, action='append')
使用:
curl http://api.example.com -d "name=bob" -d "name=sue" -d "name=joe"
获取的参数为:
args = parser.parse_args() args['name'] # ['bob', 'sue', 'joe']
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: Js 转动抽奖实现