flask项目集成swagger的方法


Posted in Python onDecember 09, 2020

 

此次主要介绍介绍在flask框架中如何集成swagger文档, 我们知道以前给同事提供接口文档主要是写一个文档, 当遇到频繁修改时,就需要更新文档非常麻烦, 这时swagger文档就出现了,一个在线得接口文档,同事可以在线上查看接口文档, 当需要修改接口时秩序修改对应得代码,文档也会随之更新。如下图所示。

flask项目集成swagger的方法

此次集成参考flask-restplus官方文档,flask-restplus框架是flask-restful框架的一个加强版, 类似django框架的rest framework框架,应用前得先安装框架执行命令:

pip install flask-restplus

然后结合官网写个简单示例感受一下:

from flask import Flask
from flask_restplus import Api, Resource, fields, reqparse

app = Flask(__name__)
api = Api(app, version='1.0', title='TodoMVC API', description='A simple TodoMVC API',)

ns = api.namespace('todo', description='TODO operations')               # 模块命名空间

todo = api.model('Todo', {                               # 返回值模型
  'id': fields.Integer(readonly=True, description='The task unique identifier'),
  'task': fields.String(required=True, description='The task details')
})

parser = reqparse.RequestParser()                      # 参数模型
parser.add_argument('id', type=str, required=True, help="id")
parser.add_argument('name', type=str, required=True, help="名称")
parser.add_argument('volume', type=int, required=True, help="方量")


class TodoDAO(Resource):
  def __init__(self, *args, **kwargs):
    super().__init__(*args, **kwargs)
    self.params = parser.parse_args()

  @ns.expect(parser)                  # 用于解析对应文档参数,             
  @ns.response(200, "success response", todo)      # 对应解析文档返回值
  def get(self):
    return self.params


ns.add_resource(TodoDAO, "/to", endpoint="to_do")

app.run()

我们启动得地址为127.0.0.1:5000得地址, 然后我们只需在浏览器打开即可查看自己写好得api文档,如下图:

flask项目集成swagger的方法

好了,至此我们已经集成好了swagger文档, 需要更详细得内容可以参考官网文档, 比方更改文档地址等。

以上就是flask项目集成swagger的方法的详细内容,更多关于flask项目集成swagger的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python警察与小偷的实现之一客户端与服务端通信实例
Oct 09 Python
Django与遗留的数据库整合的方法指南
Jul 24 Python
Python下rrdtool模块的基本使用方法
Nov 13 Python
python内置函数:lambda、map、filter简单介绍
Nov 16 Python
Python序列循环移位的3种方法推荐
Apr 09 Python
python 递归深度优先搜索与广度优先搜索算法模拟实现
Oct 22 Python
Python实现多进程的四种方式
Feb 22 Python
Python 2/3下处理cjk编码的zip文件的方法
Apr 26 Python
Django使用消息提示简单的弹出个对话框实例
Nov 15 Python
Python发送手机动态验证码代码实例
Feb 28 Python
python opencv人脸识别考勤系统的完整源码
Apr 26 Python
Python多个MP4合成视频的实现方法
Jul 16 Python
python的dict判断key是否存在的方法
Dec 09 #Python
python RSA加密的示例
Dec 09 #Python
python中把元组转换为namedtuple方法
Dec 09 #Python
python不同版本的_new_不同点总结
Dec 09 #Python
python中_del_还原数据的方法
Dec 09 #Python
call在Python中改进数列的实例讲解
Dec 09 #Python
python中的对数log函数表示及用法
Dec 09 #Python
You might like
利用PHP制作简单的内容采集器的代码
2007/11/28 PHP
php2html php生成静态页函数
2008/12/08 PHP
php数据结构之顺序链表与链式线性表示例
2018/01/22 PHP
javascript 学习笔记(六)浏览器类型及版本信息检测代码
2011/04/08 Javascript
JavaScript中的私有/静态属性介绍
2012/07/26 Javascript
浅谈JavaScript的Polymer框架中的事件绑定
2015/07/29 Javascript
javascript实现图片上传前台页面
2015/08/18 Javascript
利用jQuery实现漂亮的圆形进度条倒计时插件
2015/09/30 Javascript
分享10个优化代码的CSS和JavaScript工具
2016/05/11 Javascript
Angular.JS判断复选框checkbox是否选中并实时显示
2016/11/30 Javascript
JS图片压缩(pc端和移动端都适用)
2017/01/12 Javascript
从零学习node.js之文件操作(三)
2017/02/21 Javascript
微信小程序 chooseImage选择图片或者拍照
2017/04/07 Javascript
vue iview实现动态路由和权限验证功能
2018/04/17 Javascript
jQuery实现常见的隐藏与展示列表效果示例
2018/06/04 jQuery
在微信小程序里使用watch和computed的方法
2018/08/02 Javascript
vue+axios+mock.js环境搭建的方法步骤
2018/08/28 Javascript
Javascript 关于基本类型和引用类型的个人理解
2019/11/01 Javascript
JavaScript碰撞检测原理及其实现代码
2020/03/12 Javascript
javascript 易错知识点实例小结
2020/04/25 Javascript
详谈Object.defineProperty 及实现数据双向绑定
2020/07/18 Javascript
python简单的函数定义和用法实例
2015/05/07 Python
python Django批量导入数据
2016/03/25 Python
python中使用正则表达式的连接符示例代码
2017/10/10 Python
浅谈Python peewee 使用经验
2017/10/20 Python
python单线程文件传输的实例(C/S)
2019/02/13 Python
python创建子类的方法分析
2019/11/28 Python
Python MySQLdb 执行sql语句时的参数传递方式
2020/03/04 Python
keras实现多GPU或指定GPU的使用介绍
2020/06/17 Python
安装python依赖包psycopg2来调用postgresql的操作
2021/01/01 Python
硕士研究生求职自荐信范文
2014/03/11 职场文书
《北京的春节》教学反思
2014/04/07 职场文书
教师学习群众路线心得体会
2014/11/04 职场文书
2014年就业工作总结
2014/11/26 职场文书
学生会辞职信
2015/03/02 职场文书
党组织关系的介绍信模板
2019/06/21 职场文书