寫這個(gè)文章的主要原因,就是因?yàn)闆](méi)有相關(guān)的東西,導(dǎo)致我完全不知道應(yīng)該怎么做,經(jīng)過(guò)了兩個(gè)晚上的摸索,終于搞清楚了,如果有誰(shuí)需要tornado+swagger的輸出模式,可以照這個(gè)套;
主要是static文件的生成
我們用swagger就是為了做一個(gè)靜態(tài)頁(yè)面,也就是生成一個(gè)static文件:
幾個(gè)必備的工具:swagger-py-codegen我們不用他們的文件框架只需要其生成的static文件,拷貝到自己文件夾下即可;
1)需要注意的是生成文件需要用yaml文件,當(dāng)編輯好文件后,最主要的是要注意base_path文件的改動(dòng),你生成的文件的請(qǐng)求會(huì)加上你basepath的內(nèi)容,會(huì)造成請(qǐng)求出錯(cuò), 比如 你的url:port/GET?testparas=test,那么如果說(shuō)你的static文件生成的過(guò)程中,如下圖所示
2)生成的文件,swagger-ui中的swagger.json文件是按照你的yaml文件生成的,index.html文件中是有地方設(shè)置swagger.json的地址的,如下圖所示
3)這個(gè)時(shí)候我們可以啟動(dòng)我們的swagger程序,
接下來(lái)接受一下tornado中的一些設(shè)置,主要為application的設(shè)置:
在這里其實(shí)沒(méi)用到tornado的高級(jí)方法,只是隨意設(shè)置了一個(gè)參數(shù)進(jìn)行測(cè)試:
`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)聽(tīng)端口 app.listen(8000) tornado.ioloop.IOLoop.current().start()`
目錄結(jié)構(gòu)如下
生成swagger-ui的代碼如下:
swagger_py_codegen -s api.yaml project-one -p demo -tlp=tornado --ui --spec
其中 ?Cui ?Cspec是生成swagger-ui的關(guān)鍵代碼
以上這篇python-tornado的接口用swagger進(jìn)行包裝的實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
