本文實例講述了Sanic框架基于類的視圖用法。分享給大家供大家參考,具體如下:
簡介
基于類的視圖只是實現對請求響應行為的類,他們提供了一種在同一端點上劃分不同HTTP請求類型的處理方式。不是定義和裝飾三個不同的處理函數,而是為每個端點支持的請求類型分配一個處理函數,可以為端點分配一個基于類的視圖。
定義視圖
基于類的視圖應該是子類HTTPMethodView
,關于HTTPMethodView
的簡單用法在前面的博文中有簡單的提到過。我們可以自定義一個類繼承于HTTPMethodView
,然后你可以在其中定義各種HTTP請求類型實施方法,如果接收到一個沒有定義方法的請求,那么將會產生一個響應:405:Method not allowed。
要在端點上注冊基于類的視圖,除了需要定義一個類來繼承HTTPMethodView
,那是不夠的,還需要調用app.add_route()
方法來進行注冊??捎玫姆椒òǎ?code>get、post
、put
、patch
和delete
。使用所有方法的類將如下所示:
from sanic import Sanicfrom sanic.views import HTTPMethodViewfrom sanic.response import textclass 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")
網址參數
如果你需要URL參數,請將其包括在方法的定義中:
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框架路由用法》中有提到,如果我們想在處理函數之前處理一些事情,我們可以使用裝飾器。同樣,在基于類的視圖中同樣可以使用裝飾器來預處理一些事情。如果你想添加裝飾器到類中,可以定義一個decorators
類變量,這些將在調用as_view()
方法時被應用:
def decorator(func): async def wrapper(request,*args,**kwargs): print("有裝飾器") response = await func(request,*args,**kwargs) return response return wrapperclass SanicView(HTTPMethodView): decorators = [decorator] async def get(self,request): return text("it is ok!")app.add_route(SanicView.as_view(),"/method_view")
新聞熱點
疑難解答