中间件是 Django 请求/响应处理的钩子框架。它是一个轻量级的、低级的“插件”系统,用于全局改Django 的输入或输出。每个中间件组件负责做一些特定的功能。
例如,Django 包含一个中间件组AuthenticationMiddleware,它使用会话将用户与请求关联起来。他的文档解释了中间件是如何工作的,如何激活中间件,以及如何编写自己的中间件。
Django 具有内置的中间件,你可以直接使用。它们被记录在 built-in middleware reference 中。
中间件类:中间件类须继承自 django.utils.deprecation.MiddlewareMixin中间件类须实现下列五个方法中的一个或多个:
def process_request(self, request): 执行视图之前被调用,在每个请求上调用回None或HttpResponse对象
def process_view(self, request, callback, callback_args,callback_kwargs): 调用视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
def process_response(self, request, response): 所有响应返回浏览器之前被用,在每个请求上调用,返回HttpResponse对象
def process_exception(self, request, exception): 当处理过程中抛出异常时用,返回一个HttpResponse对象
def process_template_response(self, request, response): 在视图刚好执行之后被调用,在每个请求上调用,返回实现了render方法的响应对象
注: 中间件中的大多数方法在返回None时表示忽略当前操作进入下一项事件,当返HttpResponese对象时表示此请求结果,直接返回给客户端
编写中间键类:
from django.http import HttpResponse, Http404
from django.utils.deprecation import MiddlewareMixin
class MyMiddleWare(MiddlewareMixin):
def process_request(self, request):
print(“中间件方法 process_request 被调用”)
def process_view(self, request, callback, callback_args, callback_kwargs):
print(“中间件方法 process_view 被调用”)
def process_response(self, request, response):
print(“中间件方法 process_response 被调用”)
return response
def process_exception(self, request, exception):
print(“中间件方法 process_exception 被调用”)
def process_template_response(self, request, response):
print(“中间件方法 process_template_response 被调用”)
return response
在settings.py中注册中间键:
MIDDLEWARE = [
…
‘middleware.mymiddleware.MyMiddleWare’, ]
可以使用中间键来增加验证码
在爬虫scrapy框架中可以使用中间键来增加User-Agent 或者随机生成代理。