Flasgger - 为Flask快速生成Swagger文档
yuyutoo 2024-10-12 01:51 7 浏览 0 评论
接手了一个用Flask写的API项目,但一看到项目里那散落着的残缺的Markdown文档,你就觉得头大。
能不能生成一个可以清晰描述接口,还能进行交互测试的文档呢?
Swagger,这个用于生成、描述、调用和可视化 RESTful 风格的 Web 服务框架,已经成为 API 文档的事实标准。
而 Flasgger,把 Swagger 带给了 Flask。
简介
Flasgger,是 flasgger 组织在Github上开源的解析和渲染 SwaggerUI 的 Flask 拓展。
其提供了对于Swagger文档标准的解析和SwaggerUI的生成,支持使用YAML、Python字典和Marshmallow Schema的定义,
支持使用JSON Schema进行数据验证,支持Flask-RESTful框架的使用,对于使用Flask框架的开发者而言十分方便。
安装
使用 pip 安装即可:
pip install flasgger
如果需要使用 Marshmallow Schema,那么还需要依赖
pip install marshmallow apispec
示例
Flasgger支持直接在docstring中进行文档YAML格式的定义:
from flask import Flask, jsonify
from flasgger import Swagger
app = Flask(__name__)
swagger = Swagger(app)
@app.route('/colors/<palette>/')
def colors(palette):
"""Example endpoint returning a list of colors by palette
This is using docstrings for specifications.
---
parameters:
- name: palette
in: path
type: string
enum: ['all', 'rgb', 'cmyk']
required: true
default: all
definitions:
Palette:
type: object
properties:
palette_name:
type: array
items:
$ref: '#/definitions/Color'
Color:
type: string
responses:
200:
description: A list of colors (may be filtered by palette)
schema:
$ref: '#/definitions/Palette'
examples:
rgb: ['red', 'green', 'blue']
"""
all_colors = {
'cmyk': ['cian', 'magenta', 'yellow', 'black'],
'rgb': ['red', 'green', 'blue']
}
if palette == 'all':
result = all_colors
else:
result = {palette: all_colors.get(palette)}
return jsonify(result)
app.run(debug=True)
这是一个完整的Flask 应用例子,我们定义了一个接口,它接受色调参数,返回颜色的列表。
可以看到,可以直接把Swagger的文档定义直接放在接口的docstring中,进行了包括参数、数据结构定义、示例响应等的定义。
运行应用,Flassger就会对文档定义进行解析,并生成SwaggerUI的文档界面。
运行后,访问 http://localhost:5000/apidocs/,就会看到生成的文档界面。
可以看到,这是Swagger提供的文档界面,上面包含了我们刚刚定义的接口的定义。
此外,展开参数栏,我们可以看到接口的参数palette的类型和可选值等描述,
并且可以进行接口的测试,调用接口,并显示返回的HTTP响应。
文档中还展示了我们定义的数据类型。
此外,我们还可以把文档写在独立的YAML文件中,再在接口中引用。可以使用装饰器来引用:
from flasgger import swag_from
@app.route('/colors/<palette>/')
@swag_from('colors.yml')
def colors(palette):
...
也可以在docstring中使用file来标注:
@app.route('/colors/<palette>/')
def colors(palette):
"""
file: colors.yml
"""
...
也可以在docstring中使用file来标注:
@app.route('/colors/<palette>/')
def colors(palette):
"""
file: colors.yml
"""
...
我们也可以结合Python序列化库 Marshmallow 来进行文档的定义
class Color(Schema):
name = fields.Str()
class Palette(Schema):
pallete_name = fields.Str()
colors = fields.Nested(Color, many=True)
class PaletteView(SwaggerView):
parameters = [
{
"name": "palette",
"in": "path",
"type": "string",
"enum": ["all", "rgb", "cmyk"],
"required": True,
"default": "all"
}
]
responses = {
200: {
"description": "A list of colors (may be filtered by palette)",
"schema": Palette
}
}
我们可以看到,相比于前面使用JSON Schema的方式,这里直接引用了Marshmallow的Schema来进行数据类型的定义
此外,还可以利用Json Schema对定义的接口进行输入数据的验证等,当验证不通过就会抛出异常并返回错误信息。
@swag_from('defs.yml', validation=True)
def post():
...
总结
Flassger把Swagger引入到了Flask中,使得在Flask的API开发能够快速地进行文档的编写和展示,方便了项目的对接和后期维护。
Flassger功能众多,接口使用方便,文档丰富,目前处于稳定开发阶段。
随着Swagger向OpenAPI发展,并从2.0向3.0迈进,Flasgger也在跟进开发,感兴趣的开发者可以进一步参与开源贡献。
相关推荐
- 网络规划建设原来也可以这么简单!
-
废话少说,直接上干货。天气炎热,请各位看官老爷静心阅读。整体思路下图是关于网络建设的所有相关领域,接下来我为大家逐一讲解。网络分层...
- 网络规划设计师笔记-第 1 章 计算机网络原理
-
计算机网络原理1.1计算机网络概论(P1-10)...
- 别输在远见上,网工这样做职业规划,比啥都强
-
01职业中的规划,人生中的buff“职业规划“这个词,其实对很多年轻人,包括曾经年轻的我来说,都不屑一提。...
- 网络规划设计师学习中(个人自学笔记分享1),有一起学习的吗?
-
网络规划设计师,上午考试内容学习:第一章:计算机网络概述(上部分):如果你也在一起学习,那么我们来一起学习吧!坚持1年,争取明年一次性通过!...
- 在微服务中使用 ASP.NET Core 实现事件溯源和 CQRS
-
概述:事件溯源和命令查询责任分离(CQRS)已成为解决微服务设计的复杂性的强大架构模式。基本CQRS表示形式在本文中,我们将探讨ASP.NETCore如何使你能够将事件溯源和CQRS...
- 用 Nginx 部署 ASP.NET Core 应用程序
-
用Nginx部署ASP.NETCore应用程序步骤如下:在Linux中安装.NETCore运行时和Nginx:...
- Asp.net Core启动流程讲解(一)(asp.net core 入门)
-
asp.netcore默认项目包括项目根目录级的Startup.cs、Program.cs、appsettings.json(appsettings.Development.json)launch...
- 十天学会ASP之第五天(十天学会asp教程)
-
学习目的:学会数据库的基本操作1(写入记录)数据库的基本操作无非是:查询记录,写入记录,删除记录,修改记录。今天我们先学习写入记录。先建立一个表单:<formname="form1"met...
- ASP.NET Core 的 WebApplication 类
-
ASP.NETCore提供了3个主机类(Host)。这些类用于配置应用、管理生命周期和启动Web服务。...
- ASP.NET Core中的键控依赖注入(.net依赖注入原理)
-
大家好,我是深山踏红叶,今天我们来聊一聊ASP.NETCore中的FromKeyedServices,它是在.Net8中引入的。这一特性允许通过键(如字符串或枚举)来注册和检索依赖注入(D...
- Asp.net常用方法及request和response-a
-
asp.net教程asp.net常用方法:1、Request.UrlReferrer请求的来源,可以根据这个判断从百度搜的哪个关键词、防下载盗链、防图片盗链,可以伪造(比如迅雷)。(使用全局一般处理...
- asp.net常考面试题(aspnet题库)
-
asp.net常考面试题一,列举ASP.Net页面之间传递值的几种方式?1,使用QueryString,如:......?id=1;response.Redirect()......2,使用Sessi...
- 在Windows系统搭建.NET Core环境并创建运行ASP.NET网站
-
微软于6月27日在红帽DevNation峰会上正式发布了.NETCore1.0、ASP.NET1.0和EntityFrameworkCore1.0,其将全部支持Windows、OSX和...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)