1.django中间件的调用方式
我们可以自定义的编写属于自己的中间件。也就是需要编写一个类,然后里面定义4个方法
process_request(self, request), process_view(self, request, callback_args, callback_kwargs), process_exception(self, request, exception), process_response(self, request, response)
注意,这几个方法名称,包括函数的参数都要写成这样才行
然后在setting.py里面添加我们的中间件。
配置文件里面添加中间件的规范是,第一个是文件夹名称,例如django就是一个文件夹名称。第二个是,文件夹下面的文件名。第三个就是文件里面的类名,这样就是自定义了一个自己的中间件。当添加到配置文件之后,请求来了这个中间件就会被自动调用并执行,如果请求顺利的话,中间件里面这几个方法的执行顺序的。 process_request, process_view, (执行完这个之后就执行view里面的函数)process_response
如果你的类文件里面,定义了两个中间件,要想两个中间件都使用也是setting里面配置上两个中间件。
然后当请求来了之后,中间件的执行流程的,先执行第一个中间件里面的process_request
再执行第二个中间件的process_request,然后执行第一个中间件里面的process_view.再执行第二个中间件里面的process_view以此类推
2.Django中间件的使用
中间件(middleware)
中间件应用于request与服务端之间和服务端与response之间,客户端发起请求到服务端接收可以通过中间件,服务端返回响应与客户端接收响应可以通过中间件,也就是说中间件可以处理request和response。
Django默认的中间件
在settings中Django以及默认添加了许多有用的中间件
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
上面的配置中的中间件是有顺序的,从上到下依次通过,我们自定义的中间件如果使用的话也要按照正确的顺序添加到这里
中间件中的方法
中间件中有5个方法可以定义:
- process_request(self,request)
- process_view(self, request, callback, callback_args, callback_kwargs)
- process_template_response(self,request,response)
- process_exception(self, request, exception)
- process_response(self, request, response)
process_request
- 客户端发来请求与路由匹配执行之前执行
- 返回值是None时,继续向后执行下一个中间件的process_request或路由映射
- 返回值是HttpResponse对象时,不执行路由与views函数,直接执行该中间件与其之前的process_response,倒序执行
process_view
- 在执行完所有中间件的process_request与路由映射之后,views函数执行之前执行
- 执行顺序依然从第一个中间件到最后一个中间件
- callback参数为执行的views函数
- callback_args, callback_kwargs为views函数的参数
- 返回值是None时,继续向后执行下一个中间件的process_view或views函数
- 返回值是HttpResponse对象时,不执行views函数,直接执行所有中间件的process_response,倒序执行
process_template_response
- 视图函数返回的对象有一个render()方法(或者表明该对象是一个TemplateResponse对象或等价方法)时,才被执行(并不是views函数最后返回render对象)
- 在views执行之后,process_exception执行之前执行
- 返回值必须是response
- 倒序执行
process_exception
- process_exception用于捕捉views函数中的异常
- 在process_response之前执行
- exception是views函数中产生的异常对象
- 返回值是None时继续正常执行
- 返回值是HttpResponse对象:不再执行后面的process_exception方法,直接执行process_response
- 倒序执行
process_response
- 在response返回给客户端之前执行,也就值最后经过
- 必须返回HttpResponse对象
这里要注意,在执行views函数之前的中间件的方法都是正常顺序执行,views执行之后的中间件的方法是倒序执行
这里借用https://www.jianshu.com/p/b6e65d59f508 里的图片
定义自己的中间件
from django.utils.deprecation import MiddlewareMixin
class MyMiddleware(MiddlewareMixin):
def process_request(self, request):
print('->process_request')
def process_view(self, request, view_func, view_args, view_kwargs):
print('->view')
pass
def process_exception(self, request, exception):
pass
def process_response(self, request, response):
print('->process_response')
return response
def process_template_response(self,request,response):
print('->process_template_response')
return response
3.中间件的五大方法
1、process_request : 请求进来时,权限认证 。
2、process_view : 路由匹配之后,能够得到视图函数
3、process_exception : 异常时执行
4、process_template_responseprocess : 模板渲染时执行
5、process_response : 请求有响应时执行