第10天:中间件和日志系统
目标
使用中间件处理请求前和请求后的操作,记录日志。
任务概览
- 编写自定义中间件。
- 配置日志系统,记录关键信息。
详细步骤
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的测试框架,这是确保代码质量和功能正确性的重要工具。