Django2.1.3 中間件使用詳解
環(huán)境
- Win10
- Python3.6.6
- Django2.1.3
中間件作用 中間件用于全局修改Django的輸入或輸出。
中間件常見用途
- 緩存
- 會話認(rèn)證
- 日志記錄
- 異常
中間件執(zhí)行流程
全局異常捕捉實現(xiàn)
創(chuàng)建django項目&添加app
django-admin startproject middleware cd middleware django-admin startapp app
添加app到項目
# middleware/settings.py # INSTALLED_APPS最后添加 app INSTALLED_APPS = [ 'app', ]
編輯中間件并添加到項目
注:中間件注冊訪問有一定的關(guān)聯(lián)性,位置不可以隨意放
# 創(chuàng)建app/middleware.py并編輯 from django.http import JsonResponse class CustomMiddleware: def __init__(self, get_response): print("程序啟動時執(zhí)行, 只執(zhí)行一次") self.get_response = get_response def __call__(self, request): print("中間件開始") response = self.get_response(request) print("中間件結(jié)束") return response def process_view(self, request, view_func, view_args, view_kwargs): print("請求實際函數(shù)前執(zhí)行") def process_exception(self, request, exception): print("程序異常時執(zhí)行") return JsonResponse({"msg": exception.args[0], "code": -1})
編輯middleware.setttings.py
MIDDLEWARE = [ ... 'app.middleware.CustomMiddleware' ]
編寫一個異常
# app/views.py from django.http import JsonResponse def json_response(request): print('json_response') err = 3 / 0 return JsonResponse({"msg": "ok", "code": 0})
添加到路由
# middleware/urls.py from app.views import json_response, view_response urlpatterns = [ ... path("view", view_response) ]
運行測試
訪問: http://127.0.0.1:8000/json/
結(jié)果
另一個覺用途日志記錄
# 在中間件函數(shù)process_view中添加 print("path: {}; method: {}; data: {}".format(request.get_full_path(), request.method, request.body or ''))
參考: https://docs.djangoproject.com/zh-hans/2.1/topics/http/middleware/
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Django 添加靜態(tài)文件的兩種實現(xiàn)方法(必看篇)
- django靜態(tài)文件加載的方法
- django模板加載靜態(tài)文件的方法步驟
- Django學(xué)習(xí)教程之靜態(tài)文件的調(diào)用詳解
- 詳解Django模版中加載靜態(tài)文件配置方法
- 詳解Django中間件的5種自定義方法
- 詳解Python的Django框架中的中間件
- 深入理解Django的中間件middleware
- Django框架文件上傳與自定義圖片上傳路徑、上傳文件名操作分析
- django1.8使用表單上傳文件的實現(xiàn)方法
- Django框架靜態(tài)文件處理、中間件、上傳文件操作實例詳解
相關(guān)文章
Python大數(shù)據(jù)用Numpy Array的原因解讀
一個Numpy數(shù)組由許多值組成,所有值的類型是相同的,Numpy 是Python科學(xué)計算的一個核心模塊,本文重點給大家介紹Python大數(shù)據(jù)Numpy Array的相關(guān)知識,感興趣的朋友一起看看吧2022-02-02python模擬預(yù)測一下新型冠狀病毒肺炎的數(shù)據(jù)
這篇文章主要介紹了python模擬預(yù)測一下新型冠狀病毒肺炎的數(shù)據(jù) ,需要的朋友可以參考下2020-02-02python已協(xié)程方式處理任務(wù)實現(xiàn)過程
這篇文章主要介紹了python已協(xié)程方式處理任務(wù)實現(xiàn)過程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-12-12Python解決多進(jìn)程間訪問效率低的方法總結(jié)
這篇文章主要為大家詳細(xì)介紹了當(dāng)Python多進(jìn)程間訪問效率低時,應(yīng)該如何解決?文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-09-09PyTorch中 tensor.detach() 和 tensor.data 的區(qū)別詳解
今天小編就為大家分享一篇PyTorch中 tensor.detach() 和 tensor.data 的區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01利用python將xml文件解析成html文件的實現(xiàn)方法
下面小編就為大家分享一篇利用python將xml文件解析成html文件的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12Python實現(xiàn)獲取亂序列表排序后的新下標(biāo)的示例
本文主要介紹了Python實現(xiàn)獲取亂序列表排序后的新下標(biāo)的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04