django之中间件#
中间件简介#
django中间件就类似于django的门户,所有的请求和响应都必须经过中间件才能正常通过,可以用来处理Django的请求和响应的数据。django中间件在设计到一些全局方面的功能时,作用非常大。每个中间件组件都负责做一些特定的功能。django默认有七个中间件。
django settings.py中 MIDLLEWARE配置项:
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',
]
自定义中间件#
django默认有七个中间件, 并且支持自定义中间件,给用户暴露5个自定义的方法
只要你想要做一些网站的全局性功能,你都应该考虑使用django的中间件
- 全局的用户登录校验
- 全局的用户访问频率限制
- 全局的用户权限校验
process_request(重点)#
from django.utils.deprecation import MiddlewareMixin
class MyMdd1(MiddlewareMixin):
def process_request(self, request):
print('我是第一个中间件里的process_request方法')
class MyMdd2(MiddlewareMixin):
def process_request(self, request):
print('我是第二个中间件里的process_request方法')
总结:
- 请求来的时候会按照settings配置文件中从上往下的顺序,依次执行每一个中间件内部定义的process_request方法
- 如果中间件内部没有该方法,直接跳过执行下一个中间件
- 该方法一旦返回了HttpResponse对象,那么请求会立刻停止往下走,经过同级别的process_response方法原路返回。
process_response(重点)#
def process_response(self, request, response):
"""
:param request:
:param response: 就是后端返回给前端的数据
:return:
"""
print('我是第一个中间件里的process_response方法')
return response # 必须要返回response
总结:
- 响应走的时候会按照settings配置文件中从下往上的顺序, 依次执行每一个中间件中的process_response方法
- 该方法必须要有两个形参,并且必须返回response形参,不返回直接报错
- 该方法自定义的HttpResponse对象,前端就会得到什么
process_view#
def process_view(self, request, view_func, *args, **kwargs):
print('我是第一个中间件里的process_view方法')
processview(self, request, viewfunc, viewargs, viewkwargs), 该方法有四个参数
- 路由匹配成功之后,执行视图函数之后触发
- 如果该方法返回了HttpResponse对象, 那么会从下往上一次经过每一个中间件里的process_response方法
processtemplatesresponse#
processtemplateresponse(self, request, response)
视图函数要这样写,才能触发:
def func(request):
print('我是func函数')
def render():
return HttpResponse('你好吗')
obj = HttpResponse('我不好')
obj.render = render
return obj
当你返回的对象中含有render属性指向的是一个render方法的时候才能触发, 是从下往上的顺序
process_exception#
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse, render, redirect
class MyMdd1(MiddlewareMixin):
def process_request(self, request):
print('我是第一个中间件里的process_request方法')
# return HttpResponse('我是中间件1')
def process_response(self, request, response):
"""
:param request:
:param response: 就是后端返回给前端的数据
:return:
"""
print('我是第一个中间件里的process_response方法')
return response
# return HttpResponse('我是中间件1')
def process_view(self, request, view_func, *args, **kwargs):
print('我是第一个中间件里的process_view方法')
def process_exception(self, request, exception):
print('我是第一个中间件里的process_exception方法')
class MyMdd2(MiddlewareMixin):
def process_request(self, request):
print('我是第二个中间件里的process_request方法')
def process_response(self, request, response):
print('我是第二个中间件里的process_response方法')
return response
# return HttpResponse('我是中间件2')
def process_view(self, request, view_func, *args, **kwargs):
print('我是第二个中间件里的process_view方法')
def process_exception(self, request, exception):
print('我是第二个中间件里的process_exception方法')
- 当视图函数中出现错误时,会自动触发,顺序是settings配置文件从下往上