django中间件

 

 

1.django中间件的调用方式

我们可以自定义的编写属于自己的中间件。也就是需要编写一个类,然后里面定义4个方法
process_request(self, request), process_view(self, request, callback_args, callback_kwargs), process_exception(self, request, exception), process_response(self, request, response)
注意,这几个方法名称,包括函数的参数都要写成这样才行
然后在setting.py里面添加我们的中间件。

middleware

配置文件里面添加中间件的规范是,第一个是文件夹名称,例如django就是一个文件夹名称。第二个是,文件夹下面的文件名。第三个就是文件里面的类名,这样就是自定义了一个自己的中间件。当添加到配置文件之后,请求来了这个中间件就会被自动调用并执行,如果请求顺利的话,中间件里面这几个方法的执行顺序的。 process_request, process_view, (执行完这个之后就执行view里面的函数)process_response

如果你的类文件里面,定义了两个中间件,要想两个中间件都使用也是setting里面配置上两个中间件。
然后当请求来了之后,中间件的执行流程的,先执行第一个中间件里面的process_request
再执行第二个中间件的process_request,然后执行第一个中间件里面的process_view.再执行第二个中间件里面的process_view以此类推

 

2.Django中间件的使用

中间件(middleware)

中间件应用于request与服务端之间和服务端与response之间,客户端发起请求到服务端接收可以通过中间件,服务端返回响应与客户端接收响应可以通过中间件,也就是说中间件可以处理request和response。

Django默认的中间件

在settings中Django以及默认添加了许多有用的中间件


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',
]

上面的配置中的中间件是有顺序的,从上到下依次通过,我们自定义的中间件如果使用的话也要按照正确的顺序添加到这里

中间件中的方法

中间件中有5个方法可以定义:

  • process_request(self,request)
  • process_view(self, request, callback, callback_args, callback_kwargs)
  • process_template_response(self,request,response)
  • process_exception(self, request, exception)
  • process_response(self, request, response)

process_request

  • 客户端发来请求与路由匹配执行之前执行
  • 返回值是None时,继续向后执行下一个中间件的process_request或路由映射
  • 返回值是HttpResponse对象时,不执行路由与views函数,直接执行该中间件与其之前的process_response,倒序执行

process_view

  • 在执行完所有中间件的process_request与路由映射之后,views函数执行之前执行
  • 执行顺序依然从第一个中间件到最后一个中间件
  • callback参数为执行的views函数
  • callback_args, callback_kwargs为views函数的参数
  • 返回值是None时,继续向后执行下一个中间件的process_view或views函数
  • 返回值是HttpResponse对象时,不执行views函数,直接执行所有中间件的process_response,倒序执行

process_template_response

  • 视图函数返回的对象有一个render()方法(或者表明该对象是一个TemplateResponse对象或等价方法)时,才被执行(并不是views函数最后返回render对象)
  • 在views执行之后,process_exception执行之前执行
  • 返回值必须是response
  • 倒序执行

process_exception

  • process_exception用于捕捉views函数中的异常
  • 在process_response之前执行
  • exception是views函数中产生的异常对象
  • 返回值是None时继续正常执行
  • 返回值是HttpResponse对象:不再执行后面的process_exception方法,直接执行process_response
  • 倒序执行

process_response

  • 在response返回给客户端之前执行,也就值最后经过
  • 必须返回HttpResponse对象

这里要注意,在执行views函数之前的中间件的方法都是正常顺序执行,views执行之后的中间件的方法是倒序执行
这里借用https://www.jianshu.com/p/b6e65d59f508 里的图片

定义自己的中间件


from django.utils.deprecation import MiddlewareMixin

class MyMiddleware(MiddlewareMixin):
    def process_request(self, request):
           print('->process_request')
    def process_view(self, request, view_func, view_args, view_kwargs):
        print('->view')
        pass

    def process_exception(self, request, exception):
        pass
    def process_response(self, request, response):
        print('->process_response')
        return response
    def process_template_response(self,request,response):
        print('->process_template_response')
        return response

3.中间件的五大方法

 

1、process_request : 请求进来时,权限认证 。

2、process_view : 路由匹配之后,能够得到视图函数

3、process_exception : 异常时执行

4、process_template_responseprocess : 模板渲染时执行

5、process_response : 请求有响应时执行

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值