使用apidoc管理RESTful風(fēng)格Flask項(xiàng)目接口文檔方法
使用apidoc管理RESTful風(fēng)格Flask項(xiàng)目接口文檔方法
1.安裝nodejs
sudo apt-get install nodejs sudo apt install nodejs-legacy sudo apt install npm
2.安裝apidoc
npm install apidoc -g
3.Flask擴(kuò)展包安裝
pip install flask-apidoc
4.添加擴(kuò)展包到Flask項(xiàng)目
依賴環(huán)境
flask>=0.10.1 flask_script>=2.0.5
manage.py項(xiàng)目啟動(dòng)腳本配置
from views import app
from flask_apidoc.commands import GenerateApiDoc
from flask_script import Manager
manager = Manager(app)
manager.add_command('apidoc', GenerateApiDoc())
if __name__ == "__main__":
manager.run()
apidoc.json配置
必須在項(xiàng)目根目錄下建立apidoc.json配置文件
{
"name": "Flask REST API",
"version": "1.0.0",
"description": "A Flask REST API example",
"title": "A Flask REST API example",
"url" : "http://localhost:5000"
}
視圖函數(shù)文檔注釋說明示例
# -*- coding: utf-8 -*-
from flask import Flask
from flask_apidoc import ApiDoc
app = Flask(__name__)
doc = ApiDoc(app=app)
@app.route('/users', methods=['POST'])
def register():
"""
@api {post} /api/v1.0/users 注冊(cè)
@apiVersion 1.0.0
@apiName register_user
@apiGroup Users
@apiParam {String} mobile (必須) 用戶手機(jī)號(hào)
@apiParam {String} password (必須) 用戶密碼
@apiParam {String} sms_code (必須) 用戶短信驗(yàn)證碼
@apiParamExample {json} Request-Example:
{
mobile: "13970512239",
password: "123456",
sms_code: "907896"
}
@apiSuccess (回參) {int} user_id 用戶注冊(cè)id
@apiSuccess (回參) {String} name 用戶昵稱
@apiSuccess (回參) {String} mobile 用戶注冊(cè)手機(jī)號(hào)
@apiSuccess (回參) {String} avatar 用戶頭像地址
@apiSuccess (回參) {String} create_time 用戶創(chuàng)建時(shí)間
@apiSuccessExample {json} Success-Response:
{
"errno":0,
"errmsg":"注冊(cè)成功!",
"data": {
"user_id": 1,
"name": "lynnyq",
"mobile": "13813888888",
"avatar": "http://p3ifu3dwc.bkt.clouddn.com/FjuAwxmcCtiud_nOZ",
"create_time": "2010-1-1 12:12:12"
}
}
@apiErrorExample {json} Error-Response:
{
"errno":4001,
"errmsg":"數(shù)據(jù)庫查詢錯(cuò)誤!"
}
"""
pass
5.生成RESTful風(fēng)格接口文檔
python manage.py apidoc
文檔默認(rèn)生成在項(xiàng)目根目錄下的static/docs文件夾下
6.接口文檔頁面效果


以上這篇使用apidoc管理RESTful風(fēng)格Flask項(xiàng)目接口文檔方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
django中間件及自定義中間件的實(shí)現(xiàn)方法
中間件就是在目標(biāo)和結(jié)果之間進(jìn)行的額外處理過程,在Django中就是request和response之間進(jìn)行的處理,相對(duì)來說實(shí)現(xiàn)起來比較簡(jiǎn)單,這篇文章主要介紹了django中間件以及自定義中間件?,需要的朋友可以參考下2023-06-06
Python的getattr函數(shù)方法學(xué)習(xí)使用示例
這篇文章主要為大家介紹了Python的getattr方法學(xué)習(xí)使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
python中設(shè)置超時(shí)跳過,超時(shí)退出的方式
今天小編就為大家分享一篇python中設(shè)置超時(shí)跳過,超時(shí)退出的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12
超詳細(xì)注釋之OpenCV按位AND OR XOR和NOT
這篇文章主要介紹了OpenCV按位AND OR XOR和NOT運(yùn)算,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
Python通過matplotlib繪制動(dòng)畫簡(jiǎn)單實(shí)例
這篇文章主要介紹了Python通過matplotlib繪制動(dòng)畫簡(jiǎn)單實(shí)例,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12
dpn網(wǎng)絡(luò)的pytorch實(shí)現(xiàn)方式
今天小編就為大家分享一篇dpn網(wǎng)絡(luò)的pytorch實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01

