前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django中中间件学习之如何使用自定义中间件

Django中中间件学习之如何使用自定义中间件

作者头像
玖柒的小窝
修改2021-09-30 10:18:21
4770
修改2021-09-30 10:18:21
举报
文章被收录于专栏:各类技术文章~各类技术文章~

引言—— 举个小例子来讲讲: 比如:你登录一个网站,进去主页面的时候网站会显示你是否登录,你访问此网站的别的页面的时候也都会显示你是否登录。 难道你要在项目里的每个视图里都进行一次登录与否的判断么!!!这不是很麻烦了, 这时候就可以借助中间件十分简单的实现,我们只需要自定义一个中间件,重写其中的方法process_request(self,request) :,在此方法中进行登录与否的判断即可!因为此方法是在执行视图之前被调用,而且是用户的每个请求都会调用! 这就是中间件的牛逼之处!!!

中间件

现在你看这个图可能有点迷,等你给本篇文看完之后再看这个图会感觉真牛逼哈哈!

大致按照下面图讲一下流程: 用户发送请求(request)给网站,先经过中间件,然后给到urls,最终到视图层; 视图层返回响应(response)给用户,先经过中间件,最终到用户。

在这里插入图片描述
在这里插入图片描述
  • django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法。
  • 在django项目的settings文件中,有一个 MIDDLEWARE_CLASSES 变量,其中每一个元素就是一个中间件。

(1)中间件的执行顺序:

**请求以自上而下的顺序通过所有的层,view视图函数处理之后,响应以自下而上的顺序通过所有的层,期间经过的每个中间件都会对请求或者响应进行处理。 **

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

(2)中间件中可以定义5个方法,分别是:

  1. process_request(self,request) : 执行视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
  2. process_view(self, request, callback, callback_args, callback_kwargs): 调用视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
  3. process_template_response(self,request,response): 在视图刚好执行完毕之后被调用,在每个请求上调用,返回实现了render方法的响应对象
  4. process_exception(self, request, exception) 当视图抛出异常时调用,在每个请求上调用,返回一个HttpResponse对象
  5. process_response(self, request, response) 所有响应返回浏览器之前被调用,在每个请求上调用,返回HttpResponse对象

(3)自定义中间件的实操步骤:

小提醒:自定义中间件也可以放在该项目的任意可以导入的地方(但是习惯性是放在 app根目录里面)

步骤:

  1. 在主目录下创建了一个mymiddleware.py的文件;
  2. 在mymiddleware.py的文件中创建一个MyException的类;
  3. 自定义时你想要在哪一块加功能就定义相对应的方法,不用全部都定义。
在这里插入图片描述
在这里插入图片描述
  1. 注册中间件:

将自定义的中间件类MyException注册到settings.py中间件中: mucis是项目名,先找到文件所在的位置,把自定义的中间件的类添加到MIDLEWARE的列表当中!

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

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 中间件
    • (1)中间件的执行顺序:
      • (2)中间件中可以定义5个方法,分别是:
        • (3)自定义中间件的实操步骤:
        相关产品与服务
        消息队列 TDMQ
        消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档