news 2026/4/26 9:39:15

13. django中间件

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
13. django中间件

1、概述

AOP(Aspect Oriented Programming),面向切面编程,是对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。可以实现在不修改源代码的情况下给程序动态统一添加功能的一种技术。
面向切面编程,就是将交叉业务逻辑封装成切面,利用AOP的功能将切面织入到主业务逻辑中。所谓交叉业务逻辑是指,通用的,与主业务逻辑无关的代码,如安全检查,事物,日志等。若不使用AOP,则会出现代码纠缠,即交叉业务逻辑与主业务逻辑混合在一起。这样,会使业务逻辑变得混杂不清。举个例子:银行系统取款会有一个流程查询也会有一个流程。

Django的中间件,就是应用AOP技术来实现的,它是diango请求/响应处理的钩子框架,是一个轻巧的低级“插件“系统,在不修改diango项目原有代码的基础上可以全局改变diango的输入或输出,每个中间件组件负责执行某些特定功能。
PS:因为中间件改变的是全局,所以需要谨慎实用,滥用的话,会影响到服务器的性能

2、django默认中间件

diango项目默认有一些自带的中间件,如下

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


3、自定义中间件说明

如果需要增加白定义的中间件(该中间件类必须继承MiddlewareMixin (django.utils.deprecation)),一般是添加在系统的中间件之下

如:

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", # 自定义中间件 'my_app.middleware.MyMiddleware' ]

中间件中主要有以下方法(一个中间件类最少需要实现下列方法中的一个):

① process_request:处理请求对象,请求到达diango框架时,第一时间调用多个中间件之间顺序调用
参数:request
返回:
response:调用当前中间件的process_response处理

None:调用下一个中间件的process_request处理

② process_response:处理响应对象,视图函数返回response后,调用多个中间件之间倒序调用

参数:request,response
返回:
response:调用上一个中间件的process_response处理

③ process_view:视图预处理,在视图函数处理之前调用,即请求在urlconf当中匹配到对应的视图函数之后先不调用视图函数,而是先调用此方法
多个中间件之间顺序调用
参数:request,view func,view_args,view_kwargs

view _func: yrl路由匹配到的视图函数,不是字符串,是函数对象

view_args:视图函数的可变参数

view_kwargs:视图函数的可变关键字参数

返回:

response:调用最后一个中间件的process_response开始处理。

None:调用下一个中间件的process_view处理

④ process_exception:在视图函数处理过程抛出异常时调用,中间件的方法(除了process_template_response)中抛出异常不会触发

多个中间件之间倒序调用
参数:request,exception

exception:是处理过程中抛出的异常对象

返回:
response:之后的process exception都不会触发,而是直接调用最后一个中间件的process response处理

None:调用上一个中间件的process exception处理

⑤ process_template_response:默认不执行,在视图函数完成操作后调用,除非视图函数返回的response中有render方法
多个中间件之间倒序调用
参数:request,response
response:不是HttpReponse而是具有render方法的对象,譬如:SimpleTemplateResponse对象,在(django.template.response中)
返回:
response:具有render方法的对象,继续调用上一个中间件的processtemplate response处理,最后一个process_template_response处理完成后,会自动调用response对象中的render方法,得到一个HttpResponse对象,进行返回,再调用processresponse操作

中间件方法的执行时有顺序的,process_request与process_view是按照顺序去执行的,而
process_response、process_exception和process_template_response是反序的

总结:用户请求>>process request>>urlconf路由匹配,找到对应的视图函数>>process _view >>视图函数>> process_template_response(如果视图函数返回的response,有render方法,否则这一步不会执行)>>process response>>返回respanse到用户
其中,在视图函数和 process_template_response 处理过程中,如果出现 exception,那么就会倒序执行中间件的process_exception

4、常见自定义中间件功能

总之,你如果有对全局request或response的操作需求,那么就可以使用中间件,譬如:
1.IP过滤:对一些特定IP地址返回特定响应

2.URL过滤:如果用户访问的是login视图,则通过;如果访问其他视图,需要检测是不是有session已经有了就通过,没有就返回login页面。这样就不用在多个视图函数上写装饰器login_required

3.内容压缩:response内容实现gzip的压缩,返回压缩后的内容给前端

4.CDN:内容分发网络,实现缓存,如果缓存中有数据直接返回,没有找到缓存再去请求视图5.URL过滤:某个子应用升级暂停使用,某个特定的path路径下的请求,返回一个特定页面

5、示例项目

1.新建django项目:middleware_study,子应用:middleware app
2.urls增加路由配置

from django.contrib import admin from django.urls import path from middleware_app import views urlpatterns = [ path("middleware_test/", views.middleware_test), ]

3. views中实现函数:

from django.http import HttpResponse from django.shortcuts import render from django.template.response import SimpleTemplateResponse class MyTemplateResponse(): def render(self): return HttpResponse('MyTemplateResponse') # Create your views here. def middleware_test(request): print("中间件测试") # raise Exception("异常") # return HttpResponse("中间件测试成功") # return SimpleTemplateResponse('middleware_app/index.html') return MyTemplateResponse()

4.增加index.html模板

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <p>SimpleTemplateResponse 测试</p> </body> </html>

5. 建立middlewaretest.py

from django.http import HttpResponse from django.utils.deprecation import MiddlewareMixin class FirstMyMiddleware(MiddlewareMixin): def process_request(self,request): print('FirstMyMiddleware process_request') def process_response(self,request,response): print('FirstMyMiddleware process_response') return response def process_view(self,request,view_func,view_args,view_kwargs): print('FirstMyMiddleware process_view') def process_exception(self,request,exception): print('FirstMyMiddleware process_exception') def process_template_response(self,request,response): print('FirstMyMiddleware process_template_response') return response class SecondMyMiddleware(MiddlewareMixin): def process_request(self,request): print('SecondMyMiddleware process_request') # return HttpResponse('SecondMyMiddleware process_request') def process_response(self,request,response): print('SecondMyMiddleware process_response') return response def process_view(self,request,view_func,view_args,view_kwargs): print('SecondMyMiddleware process_view') # return HttpResponse('SecondMyMiddleware process_view') def process_exception(self,request,exception): print('SecondMyMiddleware process_exception') return HttpResponse('SecondMyMiddleware process_exception') def process_template_response(self,request,response): print('SecondMyMiddleware process_template_response') return response.render() class ThirdMyMiddleware(MiddlewareMixin): def process_request(self,request): print('ThirdMyMiddleware process_request') def process_response(self,request,response): print('ThirdMyMiddleware process_response') return response def process_view(self,request,view_func,view_args,view_kwargs): print('ThirdMyMiddleware process_view') def process_exception(self,request,exception): print('ThirdMyMiddleware process_exception') def process_template_response(self,request,response): print('ThirdMyMiddleware process_template_response') return response

6、示例-URL过滤

1.setting:py文件中的配置


from django.contrib import admin from django.urls import path from middleware_app import views urlpatterns = [ path("middleware_test/", views.middleware_test), path("middleware_url/", views.middleware_url), ]


2.增加upgrade.html模板

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <p>当前系统正在升级,预计2022年1月1日0点0分0秒升级完成,到时欢迎使用!</p> </body> </html>

3. middleware.py


class UrlMyMiddleware(MiddlewareMixin): def process_request(self,request): if request.path.startswith('/middleware_url/'): return render(request,"middleware_app/middleware_url.html")

来源:https://www.bilibili.com/video/BV1o1ygBqESP?spm_id_from=333.788.player.switch&vd_source=559010002481cf347abbb2b3ce57ed44&p=29

免责声明

本文内容为个人在互联网学习过程中整理的笔记,旨在记录学习心得与知识要点。文中部分内容可能参考或引用了网络上的公开资料、教程或他人观点。

版权声明

  1. 原创性声明:本文部分内容为个人总结与理解,但可能包含他人观点或公开资料。
  2. 引用来源:如涉及第三方内容,本人尽力标注来源,但因网络信息庞杂,可能存在遗漏或误用的情况。
  3. 侵权处理:若您认为本文内容侵犯了您的合法权益(如著作权、版权等),请通过以下方式联系本人:
    • 留言:在本文评论区或相关平台留言说明具体情况。

收到通知后,本人将第一时间核实并采取适当措施(如删除或修正相关内容)。

使用说明

  • 本文仅供学习交流使用,请勿用于商业用途。
  • 读者可参考本文内容,但建议结合官方文档或其他权威资料进一步验证。
  • 因个人理解或笔记记录可能存在偏差,请谨慎参考。

感谢您的理解与支持!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/24 6:57:06

战网注册后显示无法登录

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言一、无法登录二、操作方法默认是美洲&#xff0c;登陆要求是中国&#xff0c;所以点击这个齿轮&#xff0c;找到中国&#xff0c;点击。后面就可以正常登陆了。总…

作者头像 李华
网站建设 2026/4/24 8:26:36

PINBAI平板电脑维修实例

在上次发布了对这台pinbai平板电脑电池不充电故障处理的稿子后&#xff0c;机器又使用了三四个星期。虽然机器工作运行基本正常&#xff0c;但是机器外壳发热严重&#xff0c;电池存不住电量的故障越来越明显。以至于最近&#xff0c;不但开机时甚至关机后也一定要连上充电器&a…

作者头像 李华
网站建设 2026/4/21 0:30:13

B站的视频怎么下载到电脑?

B站作为广受欢迎的视频平台&#xff0c;不仅聚合了大量娱乐与创意内容&#xff0c;还汇集了丰富的学习资源&#xff0c;涵盖语言学习、编程开发、考试备考等多个知识领域。在观看过程中&#xff0c;用户有时需要将视频保存至本地以便离线使用&#xff0c;目前已有多种便捷工具可…

作者头像 李华
网站建设 2026/4/23 1:32:58

放过自己,也放过你的领导

职场中&#xff0c;你是否有过这样的时刻&#xff1a;熬夜赶工完成的项目&#xff0c;领导在会议上只字未提&#xff0c;反而批评你“进度拖沓”&#xff1b;你深耕数月攻克的技术难题&#xff0c;功劳却被路过的小张轻松认领&#xff0c;还得到了公开表扬&#xff1b;你反复打…

作者头像 李华
网站建设 2026/4/25 4:54:19

论文解读|从“情感陪伴机器人”到“知识中介体”

如何让知识传播变得更有人情味&#xff1f;从“情感陪伴机器人”到“知识中介体” 一、研究问题与核心概念&#xff1a;从“情感陪伴机器人”到“知识中介体” 这篇论文关注的是一个非常具体、但在当下学术传播和人机交互场景中高度现实的问题&#xff1a;当人们希望理解“知识…

作者头像 李华
网站建设 2026/4/23 13:46:25

贵宾一位里面请!把礼簿搬进你的NAS,记录、统计一步到位

「NAS、键盘、路由器年轻就要多折腾&#xff0c;我是爱折腾的熊猫—多面手博主&#xff01;咱主打的就是一个 “技能不压身&#xff0c;干货不掺水”」引言带有Docker和虚拟机的NAS可以说是无所不能&#xff0c;但我看到这个项目的时候还是没绷住&#xff01;单纯的记账已经满足…

作者头像 李华