Django中间件的自定义

#   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,中间件,python)