python 如何使用swagger

swagger介绍swagger是一个api文档工具,集api管理,测试,访问于一体的网页版api文档工具了解更多,请访问相关网站swagger官网swaggergithubOpenApi参数说明python相关包connexionflasggerflask-swag,flask-swaggerFlask-RESTPluspythonswagger-cod…

大家好,又见面了,我是你们的朋友全栈君。

swagger 介绍

  1. swagger 是一个api文档工具,集api管理,测试,访问于一体的网页版api文档工具
  2. 了解更多,请访问相关网站
  3. swagger 官网
  4. swagger github
  5. OpenApi 参数说明

python 相关包

  1. connexion
  2. flasgger
  3. flask-swag,flask-swagger
  4. Flask-RESTPlus
  5. python swagger-codegen java 版,可生成简易版的python项目,搭配swagger-client即可使用

使用 flasgger

  • 该工具与python web 服务框架 flask 高度集成
  • 自带前端页面,无需安装其他

使用示例


注意: flasgger 中引用一个外部文件,在内网中不可访问,导致页面一直在刷新,

  1. 在源码中,找到 ui3/templates/head.html
  2. 找到 <link href="https://fonts.proxy.ustclug.org/css?family=Open+Sans:400,700|Source+Code+Pro:300,600|Titillium+Web:400,600,700" rel="stylesheet">这行
  3. 注释掉,重启服务后就可正常运行了

# 简易示例
import random
from flask import Flask, jsonify, request
from flasgger import Swagger

app = Flask(__name__)
Swagger(app)

@app.route('/api/<string:language>/', methods=['GET'])
def index(language):
    """
    This is the language awesomeness API
    Call this api passing a language name and get back its features
    ---
    tags:
      - Awesomeness Language API
    parameters:
      - name: language
        in: path
        type: string
        required: true
        description: The language name
      - name: size
        in: query
        type: integer
        description: size of awesomeness
    responses:
      500:
        description: Error The language is not awesome!
      200:
        description: A language with its awesomeness
        schema:
          id: awesome
          properties:
            language:
              type: string
              description: The language name
              default: Lua
            features:
              type: array
              description: The awesomeness list
              items:
                type: string
              default: ["perfect", "simple", "lovely"]

    """
    language = language.lower().strip()
    features = [
        "awesome", "great", "dynamic", 
        "simple", "powerful", "amazing", 
        "perfect", "beauty", "lovely"
    ]
    size = int(request.args.get('size', 1))
    if language in ['php', 'vb', 'visualbasic', 'actionscript']:
        return "An error occurred, invalid language for awesomeness", 500
    return jsonify(
        language=language,
        features=random.sample(features, size)
    )


app.run(debug=True)
  1. 打开浏览器,访问 http://127.0.0.1:5000/apidocs/
    src=https://s2.ax1x.com/2019/10/09/u4t0Jg.md.jpg
    u4t0Jg.jpg

使用配置文件方式

#! /usr/bin/python3
# -*- coding:utf-8  -*-

import random
from flask import Flask, jsonify, request
from flasgger import Swagger, swag_from

app = Flask(__name__)
Swagger(app)

@app.route('/api/<string:language>/', methods=['GET'])
@swag_from("api_get.yml")
def index(language):
    language = language.lower().strip()
    features = [
        "awesome", "great", "dynamic",
        "simple", "powerful", "amazing",
        "perfect", "beauty", "lovely"
    ]
    size = int(request.args.get('size', 1))
    if language in ['php', 'vb', 'visualbasic', 'actionscript']:
        return "An error occurred, invalid language for awesomeness", 500
    return jsonify(
        language=language,
        features=random.sample(features, size)
    )

app.run(debug=True)
  1. 将注释放入 api_get 中,再使用装饰器 swag_from 即可达成一样的效果
  2. 项目地址 https://github.com/Laurel-rao/csdn_demo/tree/master/flasgger_use

swagger 配置文件介绍

swagger,包括两大部分,一部分是全局配置,一部分是具体url的配置

  • 配置介绍,请看官网 https://swagger.io/docs/specification/basic-structure/
  • OpenAPI 介绍:
    • openAPI 是用来描述api信息的一种规范,支持 yaml 和 json 格式
    • openAPI 详情https://github.com/OAI/OpenAPI-Specification/tree/OpenAPI.next

swagger 全局配置

python 配置全局配置

  1. 全局配置,包括页面的描述,标题,服务器地址等等
swagger_config = {
    "headers": [
        ],
        "specs": [
            {
                "endpoint": 'apispec_2',
                "route": '/apispecification.json',
                "rule_filter": lambda rule: True,  # all in
                "model_filter": lambda tag: True,  # all in
            }
        ],
    "static_url_path": "/flasgger_static",
    # "static_folder": "static",  # must be set by user
    "swagger_ui": True,
    "specs_route": "/doc/"
}
template_config = {
  "info": {
    "title": "Sample API",
    "description": "Hahaha, this is a API kingdom!",
    "version": "1.0.0"
  }
}
Swagger(app, template=template_config, config=swagger_config)
  1. 详细请看 info 项配置详情
  • 项目代码请访问 github

具体使用

parameter 详解

  1. 使用 in : body,可以将参数放入请求体,适用于POST 请求
  2. swagger 中要传入一个 字典参数怎么办

未完待续,目前发现swagger 还有很多不方便的地方,暂时停更

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/128777.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号