中間件是一個鉤子框架,它們可以介入 Django 的請求和響應處理過程。 它是一個輕量級、底層的 插件 系統,用于在 全局修改 Django 的輸入或輸出 。
每個中間件組件負責完成某個特定的功能
這里介紹的中間件方法適用于 Django1.10 以上
相關文件: django middleware
Django基礎中間件
django.utils.deprecation.pyclass MiddlewareMixin(object): def __init__(self, get_response=None): self.get_response = get_response super(MiddlewareMixin, self).__init__() def __call__(self, request): response = None if hasattr(self, 'process_request'): response = self.process_request(request) if not response: response = self.get_response(request) if hasattr(self, 'process_response'): response = self.process_response(request, response) return response
以上為Django基礎中間件源碼,要習慣于看源碼,上面的這段代碼并不復雜,下面我們來一一解釋。
def __init__(self, get_response=None): self.get_response = get_response super(MiddlewareMixin, self).__init__()
熟悉 python 類的都不陌生 __init__ 方法, 這里主要是 一次性配置和初始化
def __call__(self, request): response = None if hasattr(self, 'process_request'): response = self.process_request(request) if not response: response = self.get_response(request) if hasattr(self, 'process_response'): response = self.process_response(request, response) return response
__call__
為每個請求/響應執行的代碼
self.process_request(request)
為每個請求到調用視圖之前的操作,通??梢栽谶@里做一些用戶請求頻率的控制。
self.get_response(request)
為調用視圖
self.process_response(request, response)
為調用視圖完成后的操作
自定義中間件
剛才了解了基礎中間件,現在就開始編寫我們自己的中間件。
通常我們回去繼承基礎中間件來實現自己的功能
from django.utils.deprecation import MiddlewareMixinclass PermissionMiddlewareMixin(MiddlewareMixin): """ django 中間件 """ def process_request(self, request): pass def process_response(self, request, response): return response
如果你要在請求之前做處理,需要定義 process_request() 方法,去實現相關功能
如果你要在視圖調用之后做處理,需要定義 process_response() 方法,去實現相關功能
:warning:注意 定義 process_response() 方法一定要 return response
需要將你編寫的中間件添加到 settings 中的 MIDDLEWARE 里
我這里寫了一個通過中間件限制客戶端請求頻率,有興趣的可以看一下
django中間件客戶端請求頻率限制
通過redis lua腳本對客戶端IP請求頻率限制
新聞熱點
疑難解答