首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Django在格式化程序中记录自定义属性

Django在格式化程序中记录自定义属性
EN

Stack Overflow用户
提问于 2017-06-08 06:57:28
回答 1查看 7.4K关注 0票数 20

Django如何使用日志记录来使用格式化程序中的自定义属性进行日志记录?例如,我正在考虑记录登录的用户名。

settings.py脚本中,定义了日志变量:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        },
    },
    'formatters' : {
        'info_format' : {
            'format' : '%(asctime)s %(levelname)s - %(message)s',
        },
    }
}

我希望使用一种格式,例如:

'format' : '%(asctime).19s %(levelname)s - %(username)s: %(message)s'

其中,用户名是当前登录的用户。也许可以在这里添加任何其他类型的会话变量。

这里的一种解决方法是在记录器方法上使用extra参数,它接收一个字典,其中的键是我想在格式字符串上使用的字符串:

logger.info(message, extra={'username' : request.user.username})

另一个(丑陋的)解决方法是构建message属性,以包括日志格式化程序所具有的默认属性之外的内容。

message = request.user.username + " - " + message
logger.info(message)

但是,有没有一种方法可以设置具有特定属性的格式字符串,并使Django自动将它们提供给日志API?如果%(用户名)s,例如,任何其他用户名的request.user.username ...

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-11 04:33:14

您可以使用筛选器添加自定义属性。例如:

def add_my_custom_attribute(record):
    record.myAttribute = 'myValue'
    record.username = record.request.user.username 
    return True

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
        ...
        'add_my_custom_attribute': {
            '()': 'django.utils.log.CallbackFilter',
            'callback': add_my_custom_attribute,
        }
    },
    'handlers': {
        ...
        'django.server': {
            'level': 'INFO',
            'class': 'logging.StreamHandler',
            'filters': ['add_my_custom_attribute'],
            'formatter': 'django.server',
        },            
    },
    ...
}

通过安装筛选器,您可以处理每个日志记录,并决定是否应将其从记录器传递到处理程序。

过滤器获取日志记录,其中包含日志的所有详细信息(即:时间、严重程度、请求、状态代码)。

格式化程序使用记录的属性将其格式化为字符串消息。如果将自定义属性添加到记录中,则格式化程序也可以使用这些属性。

票数 31
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44424040

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档