官方文档:中间件 | Django documentation | Django
settings.py中,中间件配置是MIDDLEWARE字段,请求时从上往下顺序执行,响应时从下往上执行。
创建中间件目录和文件,注册到settings.py中

my_middle.py文件:
python
from django.utils.deprecation import MiddlewareMixin
# 自定义函数中间件,已过时
def my_middle(get_response):
def middleware(request):
print('函数或类视图执行前的操作-----')
print(request.path)
response = get_response(request)
print('函数或类视图执行后的操作-----')
return response
return middleware
# 类中间件中提供了5个基本钩子方法,方法名是固定的,一旦实现了这些方法,会在请求与响应过程中按指定的顺序分别执行。
class SimpleMiddleware (MiddlewareMixin):
def process_request(self, request) :
# 方法名是固定的,该方法会在用户请求访问路由解析完成以后,调用视图之前自动执行
# 用途:权限,路由分发,cdn,用户身份识别,白名单,黑名单 ...
print("1.视图执行之前,会自动执行 process_request .... ")
print(request.path)
# 注意,此方法不能使用return,使用则报错 !!!
def process_view(self, request, view_func, view_args, view_kwargs):
print("2.视图接收参数以后,视图代码执行之前,会自动执行 process_view")
# 用途:进行缓存处理,识别参数,根据参数查询是否建立缓存
# 注意:
# 当前方法可以返回response对象,如果返回response对象以后,则当前对应的视图函数将不会被执行
# 也可以不返回response,则默认返回None,django就会自动执行视图函数
def process_exception(self, request, exception):
print(exception)
# 用途:进行异常的处理或者记录错误日志 # 3是视图
print("4.视图执行过程中,如果出现异常,则会自动执行 process_exception,否则不执行。")
def process_response(self, request, response):
print("5.视图执行以后,会自动执行 process_response")
# 用途:记录操作历史,记录访问历史,修改返回给客户端的数据,建立缓存
# 必须返回response对象,否则报错 !!
return response
def process_template_response(self, request, response):
# 用途:建立静态化HTML页面缓存
print("3.它必须返回一个实现了render方法的响应对象。视图执行过程中, 才会自动执行 !!! ")
return response
views.py文件实现视图函数:
python
class FormView(View):
def get(self, request):
# raise NameError
print('3.视图执行')
def render():
return HttpResponse('用户最终能够看到的结果')
obj = HttpResponse()
obj.render = render # 返回的 HttpResponse 对象中必须包含 render 属性,才能触发中间件里定义的 process_template_response 方法
return obj
当发起请求时,可在终端查看打印顺序:
