Django 2.1.3 中介軟體使用
環境
Win10 Python3.6.6 Django2.1.3
中介軟體作用
- 中介軟體用於全域性修改Django的輸入或輸出。
中介軟體常見用途
- 快取
- 會話認證
- 日誌記錄
- 異常
中介軟體執行流程

image
全域性異常捕捉實現
建立django專案&新增app
django-admin startproject middleware cd middleware django-admin startapp app
新增app到專案
# middleware/settings.py # INSTALLED_APPS最後新增 app INSTALLED_APPS = [ 'app', ]
編輯中介軟體並新增到專案
- 注:中介軟體註冊訪問有一定的關聯性,位置不可以隨意放
# 建立app/middleware.py並編輯 from django.http import JsonResponse class CustomMiddleware: def __init__(self, get_response): print("程式啟動時執行, 只執行一次") self.get_response = get_response def __call__(self, request): print("中介軟體開始") response = self.get_response(request) print("中介軟體結束") return response def process_view(self, request, view_func, view_args, view_kwargs): print("請求實際函式前執行") def process_exception(self, request, exception): print("程式異常時執行") 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) ]
- 執行測試
- 訪問: ofollow,noindex">http://127.0.0.1:8000/json/
-
結果
image
另一個覺用途日誌記錄
# 在中介軟體函式process_view中新增 print("path: {}; method: {}; data: {}".format(request.get_full_path(), request.method, request.body or ''))