首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
03 | 初识Django:Django适合做什么?
04 | 用2个命令创建一个包含用户管理功能的后台
05 | 职位管理系统:开始Django之旅 :创建一个可以管理职位的后台
06 | 职位管理系统:产品体验优化:快速迭代完善应用
07 | 职位管理系统:添加自定义页面:让匿名用户可以浏览职位列表页
08 | 职位管理系统:添加自定义页面:让匿名用户可以查看职位详情
09 | 招聘评估系统:产品背景、迭代思维与MVP产品规划
10 | 招聘评估系统:唯快不破:在产品中使用产品迭代思维
11 | 招聘评估系统:数据建模 & 企业级数据库设计原则
12 | 招聘评估系统:创建应用和模型,分组展示页面内容
13 | 招聘评估系统:如何批量从Excel文件导入候选人数据
14 | 招聘评估系统:产品体验优化:候选人列表筛选和查询
15 | 招聘评估系统:省去单独的账号管理工作:企业域账号集成
16 | 招聘评估系统:批量设置面试官:面试官的导入、授权
17 | 招聘评估系统:产品新需求 :如何导出候选人的数据到CSV
18 | 招聘评估系统:如何记录日志方便排查问题
19 | 招聘评估系统:生产环境与开发环境配置分离
20 | 招聘评估系统:产品细节完善
21 | 简历投递和面试流程:定制更美观的主题
22 | 简历投递和面试流程:定制面试官权限
23 | 简历投递和面试流程:钉钉群消息集成&通知一面面试官
24 | 简历投递和面试流程:允许候选人注册登录: 集成Registration
25 | 简历投递和面试流程:候选人简历存储:创建简历Model
26 | 简历投递和面试流程:让候选人可以在线投递简历
27 | 简历投递和面试流程:使用Bootstrap来定制页面样式
28 | 简历投递和面试流程:简历评估&安排一面面试官
29 | 简历投递和面试流程:定制列表字段,查看简历详情
30 | 简历投递和面试流程:为已有系统数据库生成管理后台
31 | Django的中间件(Middleware)
32 | 创建请求日志、性能日志记录中间件
33 | 在Django中支持多语言
34 | 错误和异常日志上报:Sentry集成
35 | 错误和异常日志上报:捕获异常上报到Sentry并发送钉钉群通知
36 | Django安全防护:防止XSS跨站脚本攻击
37 | Django安全防护:CSRF跨站请求伪造和SQL注入攻击
38 | Django Rest Framework开放API
39 | 在Django中使用缓存&Redis的使用
40 | Django与Celery 集成:Celery的使用
41 | Django与Celery集成:异步任务
42 | Django与Celery集成:定时任务
43 | 文件和图片上传功能
44 | 实践中的问题:多数据库路由
45 | Django之美:大数据量的关联外键 (autocomplete_fields)
46 | Django之美:20行代码实现只读站点ReadOnlyAdmin
47| Django之美:10行代码自动注册所有Model到Admin管理后台
48 | Django之美:Signals信号及其使用场景
49 | Django之美:CSR架构总结之Celery
50 | Django之美:Sentry&Django Rest Framework
51 | Django之美:Django的常用插件
52 | 生产环境要注意哪些事项:生产环境的应用部署
53 | 应用水平扩展:使用负载均衡
54 | 让网站访问更快:使用CDN加速
55 | 让故障在第一时间被感知到:接入监控告警
56 | 生产环境中的安全:生产环境的安全设计
57 | 生产环境中的安全:应用安全
58 | 生产环境中的安全:架构安全
59 | 生产环境中的安全:数据安全
60 | 生产环境中的安全:密码安全与业务安全
61 | 云环境中的部署:Docker容器的基础用法
62 | 云环境中的部署:如何像分发集装箱一样发布应用
63 | 云环境中的部署:开发环境的容器化&构建小镜像
64 | 云环境中的部署:什么时候需要容器编排
65 | 云环境中的部署:阿里云上搭建Kubernetes集群
66 | 云环境中的部署:管理监控容器中的Django应用
67 | 云环境中的部署:应用日志收集与查询
68 | 云环境中的持续集成:CI/CD的工作流程
69 | 云环境中的持续集成:CI/CD的基本使用
当前位置:
首页>>
技术小册>>
Django快速开发实战
小册名称:Django快速开发实战
### 31 | Django的中间件(Middleware) 在Django框架中,中间件(Middleware)是一个轻量级、底层的插件系统,它允许你在请求被视图处理之前,以及在响应被返回给客户端之后,执行代码。中间件可以用于处理各种任务,如用户认证、日志记录、输入验证、会话管理等。通过合理使用中间件,可以极大地提高Django应用的灵活性和可扩展性。本章将深入解析Django中间件的工作原理、编写自定义中间件的方法,以及如何在项目中应用和管理中间件。 #### 31.1 中间件概述 Django的中间件位于请求和响应处理流程中的关键位置,它允许开发者在Django的视图系统之外插入自己的代码。每个中间件组件都负责执行一些特定的功能,并通过Django的请求/响应处理流程链式地传递请求和响应对象。这种设计方式使得中间件成为了一个非常强大的工具,能够用于多种场景下的预处理和后处理工作。 ##### 31.1.1 中间件的工作流程 当一个请求到达Django时,它会首先经过中间件层。中间件按照在`settings.py`文件中`MIDDLEWARE`列表中的顺序被调用。每个中间件可以执行以下操作之一: 1. **处理请求**:在视图被调用之前,中间件可以对请求进行预处理,比如修改请求数据、进行用户认证等。 2. **处理响应**:在视图生成响应后,但在响应返回给客户端之前,中间件可以对响应进行后处理,如修改响应内容、添加额外的HTTP头等。 3. **短路请求**:中间件可以决定不再继续处理请求,而是直接返回一个响应。这通常用于错误处理或重定向。 请求处理完成后,响应会按照相反的顺序(即`MIDDLEWARE`列表的逆序)通过中间件层,直到返回给客户端。 ##### 31.1.2 默认的中间件 Django自带了一系列实用的中间件,这些中间件提供了诸如会话管理、CSRF保护、用户认证等功能。在`django.middleware`包下可以找到这些中间件的实现。例如,`SessionMiddleware`用于处理会话数据,`CsrfViewMiddleware`用于保护视图免受跨站请求伪造(CSRF)攻击。 #### 31.2 编写自定义中间件 虽然Django提供了丰富的默认中间件,但在实际开发中,我们往往需要根据项目需求编写自定义中间件。自定义中间件必须是一个Python类,它必须包含以下四个方法中的至少一个: - `__init__(self, get_response=None)`:初始化中间件,`get_response`参数是下一个中间件的处理函数,它将被传递给后续的中间件或视图。 - `process_request(self, request)`:在请求被视图处理之前调用。如果返回了`HttpResponse`对象,则不再继续执行后续的中间件和视图。 - `process_view(self, request, view_func, view_args, view_kwargs)`:在视图函数被调用之前调用,但在`process_request`之后。`view_func`是即将被调用的视图函数,`view_args`和`view_kwargs`分别是其位置参数和关键字参数。 - `process_response(self, request, response)`:在视图函数执行后,但在响应返回给客户端之前调用。必须返回一个`HttpResponse`对象。 - `process_exception(self, request, exception)`(可选):在视图函数抛出异常时调用。如果中间件处理了这个异常,可以返回一个`HttpResponse`对象,或者返回`None`让异常继续传递。 ##### 示例:编写一个简单的日志记录中间件 下面是一个简单的中间件示例,它会在每个请求处理前后记录日志: ```python import logging logger = logging.getLogger(__name__) class SimpleLogMiddleware: def __init__(self, get_response): self.get_response = get_response def __call__(self, request): logger.info(f"Request started: {request.path}") response = self.get_response(request) logger.info(f"Request completed: {request.path}") return response # 如果需要更详细的请求处理,可以添加process_request等方法 ``` 注意,上述示例中的中间件仅通过`__call__`方法实现了简单的日志记录功能,这是因为在某些情况下,如果不需要修改请求或响应,或者不需要在特定点短路请求,只需简单地在请求处理前后执行代码时,这种方法是足够的。然而,为了完整性和灵活性,通常建议至少实现`process_request`和`process_response`方法。 #### 31.3 在项目中使用中间件 要在Django项目中使用中间件,包括Django自带的中间件和自定义中间件,都需要在项目的`settings.py`文件的`MIDDLEWARE`列表中注册它们。`MIDDLEWARE`列表中的每个字符串都是一个Python路径,指向一个中间件类。 ##### 示例:添加自定义中间件到`MIDDLEWARE`列表 假设我们的自定义中间件名为`myapp.middleware.SimpleLogMiddleware`,则需要在`settings.py`中添加如下配置: ```python MIDDLEWARE = [ # 其他中间件... 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', # ... 'myapp.middleware.SimpleLogMiddleware', # 自定义中间件 # ... ] ``` 注意,中间件的顺序很重要,因为它们将按照列表中的顺序被调用。例如,如果你有一个需要会话数据的中间件,那么它应该放在`SessionMiddleware`之后,以确保在调用它时,会话数据已经被加载到请求中。 #### 31.4 中间件的应用场景 中间件在Django项目中有着广泛的应用场景,包括但不限于: - **用户认证**:在请求被处理之前验证用户身份。 - **权限校验**:检查用户是否有权访问特定资源。 - **日志记录**:记录请求和响应的详细信息,用于监控和调试。 - **请求和响应处理**:修改请求数据或响应内容,如添加自定义HTTP头、压缩响应体等。 - **错误处理**:捕获并处理请求处理过程中发生的异常,提供友好的错误页面或执行其他恢复操作。 - **性能监控**:测量请求处理时间,监控应用性能。 #### 31.5 总结 Django的中间件是一个强大的功能,它允许开发者在请求/响应处理流程的关键点插入自定义代码,从而实现诸如用户认证、日志记录、性能监控等多种功能。通过编写自定义中间件,并合理利用Django提供的默认中间件,可以极大地提升Django应用的灵活性和可扩展性。在实际开发中,根据项目的具体需求,合理选择和配置中间件,是构建高效、健壮Web应用的关键一步。
上一篇:
30 | 简历投递和面试流程:为已有系统数据库生成管理后台
下一篇:
32 | 创建请求日志、性能日志记录中间件
该分类下的相关小册推荐:
Django零基础入门
Django框架入门指南