Sanic框架基于類的視圖用法示例
本文實例講述了Sanic框架基于類的視圖用法。分享給大家供大家參考,具體如下:
簡介
基于類的視圖只是實現(xiàn)對請求響應行為的類,他們提供了一種在同一端點上劃分不同HTTP請求類型的處理方式。不是定義和裝飾三個不同的處理函數(shù),而是為每個端點支持的請求類型分配一個處理函數(shù),可以為端點分配一個基于類的視圖。
定義視圖
基于類的視圖應該是子類HTTPMethodView
,關于HTTPMethodView
的簡單用法在前面的博文中有簡單的提到過。我們可以自定義一個類繼承于HTTPMethodView
,然后你可以在其中定義各種HTTP請求類型實施方法,如果接收到一個沒有定義方法的請求,那么將會產(chǎn)生一個響應:405:Method not allowed。
要在端點上注冊基于類的視圖,除了需要定義一個類來繼承HTTPMethodView
,那是不夠的,還需要調(diào)用app.add_route()
方法來進行注冊。可用的方法包括:get
、post
、put
、patch
和delete
。使用所有方法的類將如下所示:
from sanic import Sanic from sanic.views import HTTPMethodView from sanic.response import text class SanicView(HTTPMethodView): def get(self,request): return text("it is get") def post(self,request): return text("it is post") def put(self,request): return text("it is put") def patch(self,request): return text("it is patch") def delete(self,request): return text("it is delete") app = Sanic() app.add_route(SanicView.as_view(),"/method_view") if __name__ == "__main__": app.run()
同樣,你也可以是用async
語法:
class SanicView(HTTPMethodView): async def get(self,request): return text("it is get") app.add_route(SanicView.as_view(),"/method_view")
網(wǎng)址參數(shù)
如果你需要URL參數(shù),請將其包括在方法的定義中:
class SanicView(HTTPMethodView): async def get(self,request,name): return text("it is get and name is {}".format(name)) app.add_route(SanicView.as_view(),"/<name>")
裝飾器
在之前的講路由的文章《Sanic框架路由用法》中有提到,如果我們想在處理函數(shù)之前處理一些事情,我們可以使用裝飾器。同樣,在基于類的視圖中同樣可以使用裝飾器來預處理一些事情。如果你想添加裝飾器到類中,可以定義一個decorators
類變量,這些將在調(diào)用as_view()
方法時被應用:
def decorator(func): async def wrapper(request,*args,**kwargs): print("有裝飾器") response = await func(request,*args,**kwargs) return response return wrapper class SanicView(HTTPMethodView): decorators = [decorator] async def get(self,request): return text("it is ok!") app.add_route(SanicView.as_view(),"/method_view")
重定向
重定向功能在之前的路由文章《Sanic框架路由用法》中也有提到,如果你想在用戶訪問某個路由時,將其自動跳轉(zhuǎn)至特定的路由,此時就可以使用重定向功能。同樣,此功能在基于類的視圖中同樣能實現(xiàn),只需要在url_for()
方法中將類名傳遞進來,而后調(diào)用redirect()
方法:
from sanic.response import redirect @app.route("/") async def home(request): url = app.url_for("SanicView") return redirect(url) class SanicView(HTTPMethodView): async def get(self,request): return text("it is get") app.add_route(SanicView.as_view(),"/method_view")
CompositionView
CompositionView的簡單使用在之前的文章《Sanic框架路由用法》當中也有簡單提到。作為HTTPMethodVIew
的替代方案,你可以使用CompositionView
在視圖類之外移動處理函數(shù)。每個HTTP請求方法的程序處理函數(shù)都在源代碼中的其他地方定義,然后使用CompositionView.add
方法添加到視圖中:
from sanic.views import CompositionView async def handle_get(request): return text("it is get") view = CompositionView() view.add(["GET"],handle_get) view.add(["POST","PUT"],lambda request: text("it is post or put")) app.add_route(view,"/composition_view")
更多關于Python相關內(nèi)容可查看本站專題:《Python入門與進階經(jīng)典教程》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。
相關文章
python3.5 + PyQt5 +Eric6 實現(xiàn)的一個計算器代碼
這篇文章主要介紹了python3.5 + PyQt5 +Eric6 實現(xiàn)的一個計算器代碼,在windows7 32位系統(tǒng)可以完美運行 計算器,有興趣的可以了解一下。2017-03-03Python最大連續(xù)區(qū)間和動態(tài)規(guī)劃
這篇文章主要介紹了Python最大連續(xù)區(qū)間和動態(tài)規(guī)劃,文章圍繞Python最大連續(xù)區(qū)間和動態(tài)規(guī)劃的相關資料展開內(nèi)容,需要的小伙伴可以參考一下2022-01-01命令行傳遞參數(shù)argparse.ArgumentParser的使用解析
這篇文章主要介紹了命令行傳遞參數(shù)argparse.ArgumentParser的使用解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02