中间件简介
django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法。
中间件的编写方式
class SimpleMiddleware:
def __init__(self, get_response):
self.get_response = get_response
def __call__(self, request):
response = self.get_response(request)
return response
其他中间件接口
from django.utils.deprecation import MiddlewareMixin
class PersonMiddleware(MiddlewareMixin):
process_request(self, request)
process_view(self, request,view_func,view_args,view_kwargs)
process_exception(self, request, exception)
process_template_response(self, request, response)
process_response(self, request, response)
process_request(self, request):是请求来到middleware的第一个方法,返回值有两种,HttpResponse或者None。
process_view(self, request,view_func,view_args,view_kwargs):
request是一个HttpRequest对象。view_func是Django即将使用的Python函数。view_args是将要传递给视图的位置参数列表,view_kwargs是将要传递给视图的关键字参数字典。
这个方法是在process_request之后执行的,返回值与process_request相同。
process_template_response(self, request, response):执行完上面两个方法后,并且拿到了最终的response,且是使用了模板的response(render类方法返回的response),就会执行此方法,可以对response进行操作。
process_response(self, request, response):当所有的流程都执行完过后会执行此方法。
process_exception(self, request, exception):只有在发生异常时才会执行此方法,接收到异常之后可以选择处理异常,然后返回一个HttpResponse,或者返回None不处理,这个时候Django会使用自己的异常模板
中间件接口的具体流程
注:process_request()与process_response()是django1.10版本的
示例解析
class TimeItMiddleware(MiddlewareMixin):
def process_request(self, request):
print("这里是request")
#return HttpResponse("这里是request")
return None
def process_view(self, request, func, *args, **kwargs):
print("这里是view")
# return HttpResponse("这里是view")
return None
def process_exception(self, request, exception):
print("这里是exception")
pass
def process_template_response(self, request, response):
print("这里是template")
# return HttpResponse("这里是template")
return response
def process_response(self, request, response):
print("这里是response")
return response
*************************************************
class test:
def __init__(self, num, request):
self.num = num
self.request = request
def render(self):
return render(self.request, "index.html", {"num": self.num})
def index(request):
print("这里是view视图函数")
1、return render(request, 'index.html', {"cont": "cont"})
2、return test(5, request)
当我们访问自己写的视图函数的时候第一次访问时是这种情况
第二次访问时
可以明显看出这几个接口的执行的顺序
多个中间件执行的顺序
这是中间件激活顺序
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',
'student.middlewares.TimeItMiddleware1',
'student.middlewares.TimeItMiddleware2',
]
可以看到,process_request和process_view是按照顺序执行的,而process_template_response和process_response是按照相反的顺序来执行的。