中间件
一、原理
中间件的作用就是对一个request请求发出的时候对其进行修改,然后发送到URL以调用view视图,而响应的response对象在到达浏览器之前,也能修改
在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法。
在django项目的settings模块中,有一个 MIDDLEWARE_CLASSES 变量,其中每一个元素就是一个中间件
也就是对Django的输入和输出做一定的处理
请求以自上而下的顺序通过所有的层,view函数处理之后,响应以自下而上的顺序通过所有的层,期间经过的每个中间件都会对请求或者响应进行处理
二、结构
中间件中可以定义5个方法,分别是:
process_request(self,request) : 执行视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
process_view(self, request, callback, callback_args, callback_kwargs): 调用视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
process_template_response(self,request,response): 在视图刚好执行完毕之后被调用,在每个请求上调用,返回实现了render方法的响应对象
process_exception(self, request, exception) 当视图抛出异常时调用,在每个请求上调用,返回一个HttpResponse对象
process_response(self, request, response) 所有响应返回浏览器之前被调用,在每个请求上调用,返回HttpResponse对象
三、使用方法
基本步骤:
- 在主目录下创建了一个py文件
- 在py文件中创建一个类
- 自定义时想要加在哪一块加功能就定义相对于的方法,不用全部都定义
1.新建一个 mymiddleware.py
from django.utils.deprecation import MiddlewareMixin
from django.http import HttpResponse
class MyExcept(MiddlewareMixin):
def process_request(self,request):
print('自定义的 process_request')
return None
def process_view(self,request,callback,callback_args,callback_kwargs):
print('自定义的 process_view')
return None
def process_template_response(self,request,response):
print('M2process_template_response')
return response
def process_response(self,request,response):
print('自定义的process_response')
return response
def process_exception(self,request,exception):
print('自定义的process_exception')
return HttpResponse(exception)
2.注册
主目录下的 settings.py
TEMPLATES 下的 context_processors
添加 'django.mymiddleware.MyExcept',