第10天:中间件和日志系统

第10天:中间件和日志系统

目标

使用中间件处理请求前和请求后的操作,记录日志。

任务概览
  1. 编写自定义中间件。
  2. 配置日志系统,记录关键信息。
详细步骤
1. 编写自定义中间件

中间件是Django中处理请求和响应的钩子,可以执行以下任务:

  • 处理请求之前的操作。
  • 处理请求之后的操作。
  • 条件性地阻止请求处理。

创建自定义中间件

python 复制代码
# myproject/myapp/middleware.py

class SimpleMiddleware:
    def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        # 处理请求之前的操作
        response = self.get_response(request)
        # 处理请求之后的操作
        return response

将中间件添加到设置

python 复制代码
# myproject/myproject/settings.py

MIDDLEWARE = [
    # ...
    'myapp.middleware.SimpleMiddleware',
    # ...
]
2. 配置日志系统

Django提供了一个灵活的日志框架,可以根据需要记录不同级别的日志。

配置日志设置

python 复制代码
# myproject/myproject/settings.py

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'file': {
            'level': 'DEBUG',
            'class': 'logging.FileHandler',
            'filename': os.path.join(BASE_DIR, 'debug.log'),
        },
    },
    'loggers': {
        'django': {
            'handlers': ['file'],
            'level': 'DEBUG',
            'propagate': True,
        },
    },
}

在中间件中使用日志

python 复制代码
# myproject/myapp/middleware.py

import logging

logger = logging.getLogger(__name__)

class LoggingMiddleware:
    def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        # 请求之前记录日志
        logger.debug(f'Request {request.method} {request.path} started')

        response = self.get_response(request)

        # 请求之后记录日志
        logger.debug(f'Request {request.method} {request.path} finished with status {response.status_code}')

        return response
学习要点
  • 理解中间件的作用以及如何编写自定义中间件。
  • 学会配置Django的日志系统。
  • 掌握如何在中间件中记录日志。
每日回顾
  • 确保自定义中间件被正确添加到项目中。
  • 检查日志文件是否按预期创建和记录信息。

通过今天的学习,你应该能够编写自定义中间件来处理请求和响应,并使用Django的日志系统记录关键信息。明天,我们将学习Django的测试框架,这是确保代码质量和功能正确性的重要工具。

相关推荐
哆啦A梦的口袋呀9 分钟前
基于Python学习《Head First设计模式》第六章 命令模式
python·学习·设计模式
努力搬砖的咸鱼11 分钟前
从零开始搭建 Pytest 测试框架(Python 3.8 + PyCharm 版)
python·pycharm·pytest
Calvex14 分钟前
PyCharm集成Conda环境
python·pycharm·conda
一千柯橘25 分钟前
python 项目搭建(类比 node 来学习)
python
sduwcgg30 分钟前
python的numpy的MKL加速
开发语言·python·numpy
大模型真好玩32 分钟前
可视化神器WandB,大模型训练的必备工具!
人工智能·python·mcp
东方佑33 分钟前
使用 Python 自动化 Word 文档样式复制与内容生成
python·自动化·word
钢铁男儿39 分钟前
Python 接口:从协议到抽象基 类(定义并使用一个抽象基类)
开发语言·python
databook1 小时前
当机器学习遇见压缩感知:用少量数据重建完整世界
python·机器学习·scikit-learn
M1A11 小时前
Python数据结构操作:全面解析与实践
后端·python