Flask 引入swagger

news2024/10/2 14:29:20

1.使用flasgger

Flasgger是 flasgger 组织在Github上开源的解析和渲染 SwaggerUI 的 Flask 拓展。

提供了对于Swagger文档标准的解析和SwaggerUI的生成,支持使用YAML、Python字典Marshmallo、Schema的定义。

支持使用JSON Schema进行数据验证,支持Flask-RESTful框架的使用,对于使用Flask框架的开发者而言十分方便。

(1)安装依赖

pip innstall flasgger

如果需要使用 Marshmallow Schema,那么还需要依赖

pip install marshmallow apispec

(2)导入模块

from flasgger import Swagger

(3)实例化对象

from flask import Flask, jsonify
from flasgger import Swagger
app = Flask(__name__)
swagger = Swagger(app)

(4)示例1

①以注释形式,直接写在代码中

@app.route('/demo/score')

def  Demo():

       """ This is using docstrings for specifications.

       ---

       tags:

       - score #接口的名称

      parameters:

        - name: 接口主体 

       in: body(传参方式,可参考postman)

       schema:

         id: score(接口的名称)

         required:(需要传的参数)

           - id

           - name

           - coruse

         properties:

           id:

             type: string

             description: 学号

           name:

             type: string

             description: 姓名

           course:

             type: string

             description: 课程

responses:

       200:

         description: XX正确

       400: 

         description: XX错误
    print("swagger示例demo")

②以独立文件 yaml文件形式引入脚本中

-- 新建一个score.yml文件 

In this example the specification is taken from external YAML file
---
tags:
  -  score
parameters:
  - name: 接口主体
    in: body
    schema:
      id: score(接口的名称)
      required:
        - id
        - name
        - course
      properties:
        id:
          type: string
          description: 学号
        name:
          type: string
          description: 姓名
        course:
          type: string
          description: 课程
responses:
   200:
      description: 响应结果正确
   400:
      description: 响应结果错误

-- 引用score.yml文件 

from flasgger import swag_from

@app.route('/demo/score', methods=[‘POST’])

@swag_from(‘score.yml’)

def score():

       ...

 或者   用下面的方式表示:

@app.route('/demo/score’, methods=[‘POST’])

def score():

    """

    file:score.yml

     """

     ...

③定义字典 

-- 新建一个specs_dict字典

specs_dict = {

        "parameters": [

        {
            "name": "接口主体",

            "in": "body"

        },

        {

            "schema" : {

                "id": "score",

                "required": {

                    "id",

                    "name",

                    "course"

                },

                "properties": {

                    "id":{

                        "type": "string",

                        "description": "学号“

                    },

                    "name":{

                        "type": "string",

                        "description": "姓名“

                    },

                    "course":{

                        "type": "string",

                        "description": "课程“

                   }  

                }        

            }

        }

        ]

        ”responses": {

            "200": {

                "description": "xx正确“

            },

            ”400“: {

                ”description": "xx错误“

            }

        }

    }

--引用字典

from flasgger import swag_from

@app.route('/demo/score’, methods=[‘POST’])

@swag_from(specs_dict)

def score():

    """

    In this example the specification is taken from specs_dict

    """

    ...

进入http://localhost:端口/apidocs/ 可显示swagger API文档

 

(5)示例2

定义了一个接口,它接受色调参数,返回颜色的列表

from flask import Flask, jsonify
from flasgger import Swagger
app = Flask(__name__)
swagger = Swagger(app)
@app.route('/colors//')
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:        t
                ype: 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)

直接把Swagger的文档定义直接放在接口的docstring中,进行了包括参数、数据结构定义、示例响应等的定义。

运行应用,Flassger就会对文档定义进行解析,并生成SwaggerUI的文档界面。

运行后,访问 http://localhost:5000/apidocs/,就会看到生成的文档界面。

(2)YAML中写再引用到脚本中

我们还可以把文档写在独立的YAML文件中,再在接口中引用。

可以使用装饰器来引用:

from flasgger import swag_from
@app.route('/colors//')
@swag_from('colors.yml')def colors(palette):   
# 也可以在docstring中使用file来标注:
@app.route('/colors//')
def colors(palette):   
     """    
        file: colors.yml    
     """ 
     pass

参考:

在flask中使用swagger(flasgger使用方法及效果展示)

利用flasgger生成FlaskAPI文档_彭世瑜的博客-CSDN博客

2.使用flask-restplus

pip install flask-restplus

参考:

flask如何嵌入swagger文档 - 简书

flask项目集成swagger - 种树飞 - 博客园

Swagger documentation — Flask-RESTPlus 0.13.0 documentation

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/95365.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Docker Desktop 向大公司宣告收费,网友大呼:是时候弃用了

在容器引擎 Docker 诞生的 8 年间,其与开源的容器编排 Kubernetes 共同推动容器技术在云计算领域的应用,也让自身在全球范围内受到了广泛的关注。可以说,做过云计算开发的程序员,十有八有学过 Docker 技术。 不过,近日…

功率计和频谱仪测量功率的差异

在射频、微波无线系统中准确的测量功率是最基本的要求,进行功率测量有多种测量设备和测试方法可以选择,如功率计测量、频谱测量等。在实际测试工作中,应确保每种方法的优点和局限性不会影响测试数据的准确性。 本文将探讨不同测试方法之间的…

ssh+mysql实现的Java web论坛系统源码+视频运行教程+参考论文+开题报告

今天给大家来演示一下一款有springstruts2hibernatemysql实现的Java web论坛系统源码,本系统功能类似与csdn论坛,用户发帖时可以设置积分,当结帖时可以选择给评论的用户给与相应的分值,功能非常完善,已经接近可以直接上…

经验分享:应届生如何入行软件测试?我学习3个月成功上岸12K

推荐阅读: [内部资源] 想拿年薪30W的软件测试人员,这份资料必须领取~ Python自动化测试全栈性能测试全栈,挑战年薪40W 从功能测试进阶自动化测试,熬夜7天整理出这一份超全学习指南【附网盘资源】 正文 软件测试工程师 XXX / 应届毕业生 …

开源BI报表工具Metabase初体验

概述 一款开源BI工具,后端是用clojure开发的。官网,GitHub。 安装 安装非常简单,以metabase.jar包(后文简称jar包)方式分发。在GitHub Release页面下载最新版即可。也可以通过wget命令下载: wget http:/…

力扣383.赎金信(java语言散列表法)

题目描述: 给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。 如果可以,返回 true ;否则返回 false 。 magazine 中的每个字符只能在 ransomNote 中使用一次。 解题思…

KVM - 虚机内核配置

缘起 笔者最近分别购买了一台腾讯云和百度云的机器,都是一年期的,配置和价格分别如下: 腾讯云百度云配置2 核,2G 内存,40G 硬盘2 核,4G 内存,80G 硬盘价格50 元78 元 似乎性价比都差不多&…

802.11协议:wifi

802.11协议 博客链接:https://www.blog.23day.site/articles/71 一、协议简介 IEEE 802协议簇是指IEEE标准中关于局域网(LAN)和城域网(MAN)的一系列标准。IEEE 802中定义的服务和协议限定在OSI七层网络模型的最低两层…

m基于FPGA的NBDP系统ARQ单元模块的verilog实现

目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 NBDP(窄带直接印字电报),全称Narrow-Band Direct-Printing。是GMDSS地面无线民系统中的一种重要通信技术,这个终端设备,要与MF、HF设备…

阿里云国际版代充-阿里云无影云桌面是什么?

阿里云国际版无影云桌面的原产品名为弹性云桌面,融合了无影产品技术后更名升级。它可以为用户提供易用、安全、高效的云上桌面服务,帮助快速构建、高效管理桌面办公环境,提供安全、灵活的办公体系。 阿里云国际版无影云桌面分类:…

微信商城怎么开通【微信商城】

微信商城又可以称为微商城,微信商城是很多商家企业作为线上销售的一个平台,毕竟在微信这个这么高日活量的社交平台上,自然会有很多潜在顾客。那么如果想在微信上卖货的商家企业怎么开通微信商城呢,下面给大家说说微信商城怎么开通…

计算机网络实验二:ARP欺骗

计算机网络实验二:ARP欺骗 博客链接:https://www.blog.23day.site/articles/66 一、wireshark 要求:配置并使用wireshark,在无线环境下监听非本机的数据码流,记录并解释如下集中情况下听到的数据包的意义,…

Python爬取福利图要在中午,因为早晚会出事!我才存了2000文件夹

爱美之心人皆有之,我们爬取找寻这些漂亮小姐姐的图片并不是出于什么龌龊的目的。而是欣赏美好的东西总是会让人心情愉悦的,对于美丽事物的追求是人与生俱来的天性。 爬虫成果 发现很多想要学习Python却不知道该怎么下手的朋友,正好我这里整…

基于场景的数据集------明厨亮灶数据集

为了和各位开发爱好者深入合作交流,特此准备分批次开放数据集拱大家交流学士研究使用,整理的非常细腻,有些是专业队伍标注的,主要是菲律宾那边的团队进行标注的。依据众多算法搭建的算法平台主体算法包括 人脸识别,人…

Vue3-ElemenPlu,全栈开发后台系统-JWT方案讲解第三章-Koa架构设计接口方面实现mongdb安装配置工具函数的封装前台首页实现

第三章-Koa架构设计 #!/usr/bin/env node/*** Module dependencies.*/var app = require(../app); var debug = require(debug)

公司新来的00后真是卷王,工作没两年,跳槽到我们公司起薪18K都快接近我了

都说00后躺平了,但是有一说一,该卷的还是卷。这不,前段时间我们公司来了个00后,工作没两年,跳槽到我们公司起薪18K,都快接近我了。后来才知道人家是个卷王,从早干到晚就差搬张床到工位睡觉了。 …

【LVGL学习笔记】(一)环境搭建

LVGL全程LittleVGL,是一个轻量化的,开源的,用于嵌入式GUI设计的图形库。并且配合LVGL模拟器,可以在电脑对界面进行编辑显示,测试通过后再移植进嵌入式设备中,可以高效地进行开发。 一.嵌入式设备的移植 L…

开发Java Web项目基础储备

大家好,我是邵奈一,一个不务正业的程序猿、正儿八经的斜杠青年。 1、世人称我为:被代码耽误的诗人、没天赋的书法家、五音不全的歌手、专业跑龙套演员、不合格的运动员… 2、这几年,我整理了很多IT技术相关的教程给大家&#xff0…

互联网寒冬下奇葩公司行为艺术一览!你就是想笑死我继承我的代码

干货不少,有图有真相,大家慢慢看下去! 既然创业,我为什么不自己当老板,要去给你当合伙人?是为了那1K-2K的高薪吗? 这招的不是高级工程师与合伙人,招的怕不是个傻子! 有…

[激光原理与应用-58]:激光器 - 光学 - 常见光学镜片的特性

目录 一、纯度 二、透明度与透光率 三、均匀度 四、折射率 五、色散率 六、反射率 七、透光率 八、光线吸收率 一、纯度 光学纯度又称旋光纯度。 二、透明度与透光率 透光率,表示光线透过介质的能力,是透过透明或半透明体的光通量与其入射光…