這篇文章將為大家詳細講解有關Sanic框架異常處理與中間件操作的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
目前成都創(chuàng)新互聯(lián)已為1000+的企業(yè)提供了網站建設、域名、網站空間、網站運營、企業(yè)網站設計、羅源網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。簡介
Sanic是一個類似Flask的Python 3.5+ Web服務器,它的寫入速度非???。除了Flask之外,Sanic還支持異步請求處理程序。這意味著你可以使用Python 3.5中新的閃亮的異步/等待語法,使你的代碼非阻塞和快速。
前言:Sanic最低支持Python 3.5,如果需要學習Sanic,請先下載版本不低于3.5的Python包
異常
異??梢詮恼埱筇幚沓绦蛑袙伋?,并由Sanic自動處理。異常將消息作為第一個參數,并且還可以將狀態(tài)碼傳回HTTP響應中。
拋出異常:手動產生異常的方式,有過Python基礎的都知道,可以使用raise
來產生一個異常:
from sanic.exceptions import ServerError from sanic.response import text @app.route("/get_exception") async def get_exception(request): raise ServerError("it is error",status_code=500)
你也可以使用abort:
from sanic.exceptions import abort from sanic.response import text @app.route("/get_exception") async def get_exception(request): abort(402) text("ok")
處理異常:有時我們需要對一些特殊異常做特殊處理,此時我們可以用到@app.exception
裝飾器,然后在定義一個異常函數來進行處理。異常裝飾器處理函數必須以一個Request
和Exception
對象作為參數:
from sanic.response import text from sanic.exceptions import NotFound @app.exception(NotFound) async def not_found_exception(request,exception): return text("not found=>{}".format(request.url))
中間件
中間件是服務器在請求之前或之后執(zhí)行的功能,他們可以用來修改修改用戶定義處理函數的請求或相應。Sanic提供兩種類型的中間件:請求和響應。兩者都是使用@app.middleware
裝飾器聲明,兩個裝飾器分別需要傳入一個代表其類型的參數:request
和response
,下面舉一個簡單的栗子:
from sanic.response import text @app.route("/get_info") async def get_info(request): print(request.url) return text("it is ok!") @app.middleware("request") async def get_request_middleware(request): print("請求中間件") @app.middleware("response") async def get_response_middleware(request,response): print("響應中間件")
當我們訪問/get_info
請求時,打印結果將會是這樣的:
請求中間件
http://localhost:5000/get_info
響應中間件
值得注意的是,如果是響應中間的處理函數,除了需要傳遞一個request
對象參數,還需要傳遞一個response
對象參數。從結果可以看出,request
中間件是在接收到請求時立馬觸發(fā)的,而response
中間件是在接收到響應時立馬觸發(fā)的。針對這兩者的特性,我們可以進行一些特殊的操作,來達到我們的目的:
@app.middleware("request") async def get_request_middleware(request): request.args.update({"name":"laozhang"}) @app.middleware("response") async def get_response_middleware(request,response): response.headers["name"] = "laozhang"
將所有的請求的args添加一條name=laozhang
,并且在響應頭中添加name=laozhang
監(jiān)聽器
如果需要在服務器啟動/關閉的時候,執(zhí)行一些特殊的代碼,則可以使用以下監(jiān)聽器:
before_server_start:在服務器啟動之前執(zhí)行
after_server_start:在服務器啟動之后執(zhí)行
before_server_stop:在服務器關閉之前執(zhí)行
after_server_stop:在服務器關閉之后執(zhí)行
舉個栗子:
@app.listener("before_server_start") async def before_server_start(request,loop): print("before_server_start") @app.listener("after_server_start") async def after_server_start(request,loop): print("after_server_start") @app.listener("before_server_stop") async def before_server_stop(request,loop): print("before_server_stop") @app.listener("after_server_stop") async def after_server_stop(request,loop): print("after_server_stop")
現(xiàn)在先啟動服務,而后關閉,發(fā)現(xiàn)執(zhí)行的順序將會是這樣:
before_server_start
after_server_start
before_server_stop
after_server_stop
關于“Sanic框架異常處理與中間件操作的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。