国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

django日志默認打印request請求信息的方法示例

瀏覽:6日期:2022-07-25 11:11:03

需求

請求view中手動打印日志時中插入request的如下信息(每個request請求都記錄可以使用中間件進行解決,但這里僅僅是在需要的地方手動打印):

#統(tǒng)一附加日志內(nèi)容ADD_LOG = r’’’{'username': request.user, 'path': request.path, 'request_id': request.id, 'login_id': request.login_id}’’’

舊的解決辦法

在每次需要打印日志時,通過 logging extra 進行額外的打印信息添加:每次手動添加同樣的extra非常的不優(yōu)雅。

django日志默認打印request請求信息的方法示例

新的解決方案

django 自帶log系統(tǒng)官方文檔

1、熟悉python的logging模塊結(jié)構(gòu)。

Loggers Handlers Filters Formatters

2、django中間件存儲request信息。

class RequestLogMiddleware(MiddlewareMixin): ''' 將request的信息記錄在當前的請求線程上 ''' def process_request(self, request): # 統(tǒng)一附加日志內(nèi)容 # ADD_LOG = r’’’{'username': request.user, 'path': request.path, 'request_id': request.id, 'login_id': request.login_id}’’’ local.path = request.path local.request_id = request.id local.login_id = request.login_id local.username = request.user.username

3、logging的filters模塊添加request信息。

import loggingclass RequestLogFilter(logging.Filter): ''' 日志過濾器,將當前請求線程的request信息保存到日志的record上下文 ''' def filter(self, record): record.request_id = getattr(local, ’request_id’, 'none') record.path = getattr(local, ’path’, 'none') record.login_id = getattr(local, ’login_id’, 'none') record.username = getattr(local, ’username’, 'none') record.appName = getattr(local, 'appName', 'none') return True

4、實現(xiàn)原理及代碼

通過 local = threading.local()。

middleware-waiwen文件代碼:

import threadingimport loggingtry: from django.utils.deprecation import MiddlewareMixin # Django 1.10.xexcept ImportError: MiddlewareMixin = object # Django 1.4.x - Django 1.9.xlocal = threading.local()class RequestLogFilter(logging.Filter): ''' 日志過濾器,將當前請求線程的request信息保存到日志的record上下文 record帶有formater需要的信息。 ''' def filter(self, record): record.request_id = getattr(local, ’request_id’, 'none') record.path = getattr(local, ’path’, 'none') record.login_id = getattr(local, ’login_id’, 'none') record.username = getattr(local, ’username’, 'none') return Trueclass RequestLogMiddleware(MiddlewareMixin): ''' 將request的信息記錄在當前的請求線程上。 ''' def process_request(self, request): # 統(tǒng)一附加日志內(nèi)容 # ADD_LOG = r’’’{'username': request.user, 'path': request.path, 'request_id': request.id, 'login_id': request.login_id}’’’ local.path = request.path local.request_id = request.id local.login_id = request.login_id local.username = request.user.username

settings 文件配置

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’, ’wcloud.middleware-waiwen.RequestLogMiddleware’ #使用該中間件 #將當前的request信息保存到當前線程供日志打印使用]LOGGING = { # 日志相關(guān) ’version’: 1, ’disable_existing_loggers’: False, ’formatters’: { ’standard’: {’format’: ’{'date': '%(created)f', 'level': '%(levelname)s', 'funcName': '%(module)s.%(funcName)s:%(lineno)d', 'msg': '%(message)s'}’}, # 日志格式 ’custom’: { #該格式化中包含有過濾器record新增的字段’format’: ’{'date': '%(created)f', 'level': '%(levelname)s', 'funcName': '%(module)s.%(funcName)s:%(lineno)d', 'request_id': '%(request_id)s','login_id': '%(login_id)s', 'username': '%(username)s', 'path': '%(path)s','msg': '%(message)s'}’ }, }, ’filters’: { #注冊該過濾器 ’request_info’: {’()’: ’wcloud.middleware-waiwen.RequestLogFilter’} }, ’handlers’: { ’log’: {’level’: ’DEBUG’,’class’: ’logging.StreamHandler’,’formatter’: ’custom’, #在該過handler中使用該過濾器’filters’: [’request_info’], }, ’console’: {’level’: ’DEBUG’,’class’: ’logging.StreamHandler’,’formatter’: ’standard’, }, }, ’loggers’: { ’django’: {’handlers’: [’console’],’level’: ’ERROR’,’propagate’: False }, ’django.request’: {’handlers’: [’console’],’level’: ’ERROR’,’propagate’: False }, ’django.db.backens’: {’handlers’: [’console’],’level’: ’DEBUG’,’propagate’: False }, ’log’: {’handlers’: [’log’],’level’: ’INFO’,’propagate’: True }, } }

5、效果

django日志默認打印request請求信息的方法示例

參考:

給Django日志加上request_id

總結(jié)

到此這篇關(guān)于django日志默認打印request請求信息的文章就介紹到這了,更多相關(guān)django日志默認打印request請求信息內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: django request
相關(guān)文章:
主站蜘蛛池模板: 99久久精品免费看国产一区二区三区 | 亚洲天堂免费视频 | 日韩美三级| 九九九热在线精品免费全部 | 中文字幕一区在线播放 | 日韩成人免费在线 | 久久国产精品免费观看 | 天堂资源8中文最新版在线 天堂最新版 | 深爱激情五月网 | 国内精品不卡一区二区三区 | 91影视做在线观看免费 | 亚洲天堂视频在线观看免费 | 国产高清一| 特级淫片国产免费高清视频 | 一级毛片免费在线 | 在线播放精品一区二区啪视频 | 手机看片国产免费 | 人成18亚洲资源在线 | 99草精品视频 | 久久国产免费一区 | 99精品视频观看 | 在线观看国产一区二三区 | cao在线 | 欧美日韩在线观看精品 | 日本欧美一区二区三区不卡视频 | a毛片在线还看免费网站 | 国产精品视_精品国产免费 国产精品视频久 | 欧美va在线播放免费观看 | 日韩一级影院 | 看v片| 中文字幕区 | 成人精品免费视频 | caoporen个人免费公开视频 | 日韩视频久久 | 一区二区三区不卡在线 | 亚洲精品色一区二区三区 | 中文字幕一区二区三区精品 | 国产一区二区三区手机在线观看 | 欧美特级另类xxx | 国产精品欧美韩国日本久久 | 美女张开腿让男人桶爽动漫视频 |