官方文档:中间件 | Django documentation | Django
settings.py中,中间件配置是MIDDLEWARE字段,请求时从上往下顺序执行,响应时从下往上执行。
# 创建中间件目录和文件,注册到settings.py中
# my_middle.py文件:
from django.utils.deprecation import MiddlewareMixin# 自定义函数中间件,已过时
def my_middle(get_response):def middleware(request):print('函数或类视图执行前的操作-----')print(request.path)response = get_response(request)print('函数或类视图执行后的操作-----')return responsereturn middleware# 类中间件中提供了5个基本钩子方法,方法名是固定的,一旦实现了这些方法,会在请求与响应过程中按指定的顺序分别执行。class SimpleMiddleware (MiddlewareMixin):def process_request(self, request) :# 方法名是固定的,该方法会在用户请求访问路由解析完成以后,调用视图之前自动执行# 用途:权限,路由分发,cdn,用户身份识别,白名单,黑名单 ...print("1.视图执行之前,会自动执行 process_request .... ")print(request.path)# 注意,此方法不能使用return,使用则报错 !!!def process_view(self, request, view_func, view_args, view_kwargs):print("2.视图接收参数以后,视图代码执行之前,会自动执行 process_view")# 用途:进行缓存处理,识别参数,根据参数查询是否建立缓存# 注意:# 当前方法可以返回response对象,如果返回response对象以后,则当前对应的视图函数将不会被执行# 也可以不返回response,则默认返回None,django就会自动执行视图函数def process_exception(self, request, exception):print(exception)# 用途:进行异常的处理或者记录错误日志 # 3是视图print("4.视图执行过程中,如果出现异常,则会自动执行 process_exception,否则不执行。")def process_response(self, request, response):print("5.视图执行以后,会自动执行 process_response")# 用途:记录操作历史,记录访问历史,修改返回给客户端的数据,建立缓存# 必须返回response对象,否则报错 !!return responsedef process_template_response(self, request, response):# 用途:建立静态化HTML页面缓存print("3.它必须返回一个实现了render方法的响应对象。视图执行过程中, 才会自动执行 !!! ")return response
# views.py文件实现视图函数:
class FormView(View):def get(self, request):# raise NameErrorprint('3.视图执行')def render():return HttpResponse('用户最终能够看到的结果')obj = HttpResponse()obj.render = render # 返回的 HttpResponse 对象中必须包含 render 属性,才能触发中间件里定义的 process_template_response 方法return obj
当发起请求时,可在终端查看打印顺序: