# Django中函数中间件
# 中间件定义好之后, 在setting中配置中间件的列表中进行配置其路径即可
def simple_middleware(get_response):
def middleware(request):
# 可以做一些校验工作,等等
print("视图执行之前")
response = get_response() # get_response 可以理解为视图
print("视图执行之后")
return response
return middleware
# 类中间件
# 进行类中间件的路径注册即可
from django.utils.deprecation import MiddlewareMixin
class CustomMiddleware(MiddlewareMixin):
"""中间件类"""
def process_request(self,request):
# 方法名是固定的,该方法会在用户请求访问路由解析完成以后,调用视图之前自动执行
print("1. process_request在路由解析以后,产生request对应, 视图执行之前,会执行这个方法")
# 用途:权限,路由分发,cdn,用户身份识别,白名单,黑名单...
# 注意,此方法不能使用return,使用则报错!!!
def process_view(self,request,view_func, view_args, view_kwargs):
# 用途:进行缓存处理,识别参数,根据参数查询是否建立缓存
print("2. process_view在视图接受了参数以后,没有执行内部代码之前")
# 可以返回response对象, 如果返回response对象以后,则当前对应的视图函数将不会被执行
# return HttpResponse("ok")
# 也可以不返回response,则默认返回None,django就会自动执行视图函数
def process_response(self,request,response):
print("4. process_response在视图执行以后,才执行的")
# 用途:记录操作历史, 记录访问历史,修改返回给客户端的数据, 建立缓存
# 必须返回response对象,否则报错!!
return response
def process_exception(self, request, exception):
print(exception)
# 用途:进行异常的处理或者记录错误日志
print("5. process_exception会在视图执行发生异常的时候才会执行")
def process_template_response(self,request, response):
# 用途:建立页面缓存
print("6. process_template_response只有在视图调用了模板以后,才会执行!!!")
return response
Django中间件的自定义
最新推荐文章于 2023-12-13 14:07:13 发布