中间件
Django中的中间件是一个轻量级、底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入和输出。
中间件的设计为开发者提供了一种无侵入式的开发方式,增强了Django框架的健壮性,其他的MVC框架也有这个功能,名称为loC。
使用场景:当某些操作在每次请求或响应时都会执行时,可以写在中间件中。
例如:每次发送post请求都要进行CSRF验证,就把CSRF验证的代码写在中间件中。
设计思想:面向切面编程/无侵害式编程
不用直接修改框架源码,就可以达到自己想要的执行结果。
中间件方法
Django在中间件中预置了六个方法,这六个方法的区别在于不同的阶段执行,对输入或输出进行干预。
1、处理请求前:在每个请求调用的时候,返回None或者HttpResponse对象
def process_request(request): pass
2、处理视图前:在每个请求调用的时候,返回None或者HttpResponse对象
def process_view(self, request, callback, callback_args, callback_kwargs): print("views")
3、处理响应后:所有响应返回浏览器之前被调用,在每个请求上调用,返回HttpResponse对象
def process_response(request, response): pass
4、异常处理:当视图抛出异常时调用,在每个请求上调用的时候,返回一个HttpResponse对象
def process_exception(request,exception): pass
自定义中间件
1、中间件是一个独立的python类,可以定义这6个方法中的一个或多个
2、在应用中新建middleware.py文件
3、在新建文件中自定义类:
先导入MiddlewareMixin类:中间件类继承它
from django.utils.deprecation import MiddlewareMixin
from django.utils.deprecation import MiddlewareMixin from django.shortcuts import HttpResponse class TestMiddleware(MiddlewareMixin): def process_request(self,request): print("这是request") def process_view(self,request, view_func, view_args, view_kwargs): print("到达视图函数这里啦view") def process_response(self,request,response): print("由视图函数返回来啦") return response
4、配置自定义中间件
应用.文件名.类名(Book.middleware.TestMiddleware)
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', #默认开启CSRF验证 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', #增加自定义的中间件 应用名.文件名.类名 "Book.middleware.TestMiddleware", ]
运行结果:
备注:如果中间件中注册多个类的相同方法,那么则会按照先注册的