Django-3-中间件

一、 中间件是???

  1. 中间件是request和response处理间的一道处理过程,并且在全局上改变django的输入与输出,中间件位于web服务端与url路由层之间,
  2. 当Django处理一个 Request 的过程是首先通过中间件,然后再通过默认的 URL 方式进行的。我们可以在 Middleware 这个地方把所有Request 拦截住,用我们自己的方式完成处理以后直接返回 Response

二、中间件五个方法

在这里插入图片描述

  1. 在django项目的settings模块中,有一个 MIDDLEWARE_CLASSES 变量,其中每一个元素就是一个中间件

  2. 中间件可以定义五个方法

    从前往后执行:

      process_request(self,request)  # Request预处理函数
      process_view(self, request, callback, callback_args, callback_kwargs)  # View预处理函数
    

    从后往前执行:

      process_template_response(self,request,response) # Template模版渲染函数 
      process_exception(self, request, exception) # Exception后处理函数
      process_response(self, request, response) # Response后处理函数
    
    1. Request预处理函数 process_request(self,request)

      这个方法的调用时机在Django接收到request之后,但仍未解析URL以确定应当运行的视图函数。Django向它传入相应的Request对象,以便在方法中修改。

      如果返回None,Django将继续处理这个request,执行后续的中间件, 然后调用相应的 view。

      如果返回HttpResponse对象,Django将不再执行任何除了process_response以外其它的中间件以及相应的view,Django将立即返回该HttpResponse。

    2. View预处理函数 process_view(self, request, callback, callback_args, callback_kwargs)

      这个方法的调用时机在 Django 执行完 request 预处理函数并确定待执行的 view (即callback参数)之后,但在 view 函数实际执行之前。

      request:HttpRequest 对象。

      callback:Django将调用的处理request的python函数. 这是实际的函数对象本身, 而不是字符串表述的函数名。

      args:将传入view的位置参数列表,但不包括request参数(它通常是传入view的第一个参数)。

      kwargs:将传入view的关键字参数字典。

      process_view() 应当返回None或 HttpResponse 对象。如果返回 None, Django将继续处理这个request ,执行后续的中间件, 然后调用相应的view。

      如果返回 HttpResponse 对象,Django 将不再执行任何其它的中间件(不论种类)以及相应的view,Django将立即返回。

    3. Template模板渲染函数 process_template_response(self,request,response)

      默认不执行,只有在视图函数的返回结果对象中有render方法才会执行,并把对象的render方法的返回值返回给用户(注意不返回视图函数的return的结果了,而是返回视图函数 return值(对象)中rende方法的结果)

    4. Exception后处理函数 process_exception(self, request, exception)

      这个方法只有在 request 处理过程中出了问题并且view 函数抛出了一个未捕获的异常时才会被调用。这个钩子可以用来发送错误通知,将现场相关信息输出到日志文件,或者甚至尝试从错误中自动恢复。

      这个函数的参数除了一贯的request对象之外,还包括view函数抛出的实际的异常对象exception 。

      process_exception() 应当返回None或HttpResponse对象。

      如果返回None,Django将用框架内置的异常处理机制继续处理相应request。

      如果返回HttpResponse对象,Django将使用该response对象,而短路框架内置的异常处理机制。

    5. Response后处理函数 process_response(self, request, response)

      这个方法的调用时机在 Django 执行 view 函数并生成 response 之后。

      该处理器能修改response 的内容;一个常见的用途是内容压缩,如gzip所请求的HTML页面。

      这个方法的参数相当直观:request是request对象,而response则是从view中返回的response对象。

      process_response() 必须返回 HttpResponse 对象. 这个 response 对象可以是传入函数的那一个原始对象(通常已被修改),也可以是全新生成的。

三、自定义中间件

参考文档:https://www.cnblogs.com/sui776265233/p/9664642.html

  1. 在根目录下建立:‘mymiddleware.middleware.userauth.RequestAuth’

     from django.http import HttpResponse
     from django.utils.deprecation import MiddlewareMixin
     class RequestAuth(MiddlewareMixin):
         def process_request(self,request):
             print('Mdl 请求')
     
         def process_view(self, request, callback, callback_args, callback_kwargs):
             print('Mdl 视图')
     
         def process_exception(self, request, exception):
             print('Mdl 异常')
     
         def process_response(self, request, response):
             print('Mdl 响应')
             return response
    
  2. 在settings.py的MIDDLEWARE里注册自己定义的中间件

     MIDDLEWARE = [
         'mymiddleware.middleware.userauth.RequestAuth.RequestAuth'
     ]
    

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值