python-tornado的接口用swagger進行包裝的實例
寫這個文章的主要原因,就是因為沒有相關的東西,導致我完全不知道應該怎么做,經(jīng)過了兩個晚上的摸索,終于搞清楚了,如果有誰需要tornado+swagger的輸出模式,可以照這個套;
主要是static文件的生成
我們用swagger就是為了做一個靜態(tài)頁面,也就是生成一個static文件:
幾個必備的工具:swagger-py-codegen我們不用他們的文件框架只需要其生成的static文件,拷貝到自己文件夾下即可;
1)需要注意的是生成文件需要用yaml文件,當編輯好文件后,最主要的是要注意base_path文件的改動,你生成的文件的請求會加上你basepath的內(nèi)容,會造成請求出錯, 比如 你的url:port/GET?testparas=test,那么如果說你的static文件生成的過程中,如下圖所示

2)生成的文件,swagger-ui中的swagger.json文件是按照你的yaml文件生成的,index.html文件中是有地方設置swagger.json的地址的,如下圖所示

3)這個時候我們可以啟動我們的swagger程序,

接下來接受一下tornado中的一些設置,主要為application的設置:
在這里其實沒用到tornado的高級方法,只是隨意設置了一個參數(shù)進行測試:
`import tornado.web
import tornado.ioloop
import os
abs_path = os.path.dirname(os.path.abspath("__file__"))
print(abs_path)
class IndexHandler(tornado.web.RequestHandler):
def get(self, *args, **kwargs):
para = self.get_argument('test', None)
self.write("test tornado {}".format(para))
if __name__ == '__main__':
app = tornado.web.Application([
(r'/GET', IndexHandler)
],
static_path=os.path.join(abs_path, 'static')
)
# 監(jiān)聽端口
app.listen(8000)
tornado.ioloop.IOLoop.current().start()`
目錄結構如下

生成swagger-ui的代碼如下:
swagger_py_codegen -s api.yaml project-one -p demo -tlp=tornado --ui --spec
其中 –ui –spec是生成swagger-ui的關鍵代碼
以上這篇python-tornado的接口用swagger進行包裝的實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
django學習之a(chǎn)jax post傳參的2種格式實例
AJAX除了異步的特點外,還有一個就是:瀏覽器頁面局部刷新,下面這篇文章主要給大家介紹了關于django學習之a(chǎn)jax post傳參的2種格式的相關資料,需要的朋友可以參考下2021-05-05
python神經(jīng)網(wǎng)絡Densenet模型復現(xiàn)詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡Densenet模型復現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05
下載與當前Chrome對應的chromedriver.exe(用于python+selenium)
這篇文章主要介紹了下載與當前Chrome對應的chromedriver.exe(用于python+selenium),本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
python?argparse的使用步驟(全網(wǎng)最全)
argparse是python的一個命令行參數(shù)解析包,在代碼需要頻繁修改參數(shù)時,方便使用,主要用法就是在命令行輸入自己想要修改的參數(shù),這篇文章主要介紹了python?argparse的使用步驟(全網(wǎng)最全),需要的朋友可以參考下2023-04-04

