Django 2.1.3 中介軟體使用

ilyq69發表於2018-11-25

環境

Win10
Python3.6.6
Django2.1.3
複製程式碼

中介軟體作用

  • 中介軟體用於全域性修改Django的輸入或輸出。

中介軟體常見用途

  • 快取
  • 會話認證
  • 日誌記錄
  • 異常

中介軟體執行流程

Django 2.1.3 中介軟體使用

全域性異常捕捉實現

建立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)
]
複製程式碼
  1. 執行測試

另一個覺用途日誌記錄

# 在中介軟體函式process_view中新增
print("path: {}; method: {}; data: {}".format(request.get_full_path(), request.method, request.body or ''))
複製程式碼

參考:

相關文章