色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

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

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

需求

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

#統一附加日志內容ADD_LOG = r’’’{'username': request.user, 'path': request.path, 'request_id': request.id, 'login_id': request.login_id}’’’

舊的解決辦法

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

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

新的解決方案

django 自帶log系統官方文檔

1、熟悉python的logging模塊結構。

Loggers Handlers Filters Formatters

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

class RequestLogMiddleware(MiddlewareMixin): ''' 將request的信息記錄在當前的請求線程上 ''' def process_request(self, request): # 統一附加日志內容 # 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、實現原理及代碼

通過 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): # 統一附加日志內容 # 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 = { # 日志相關 ’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

總結

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

標簽: django request
相關文章:
主站蜘蛛池模板: 日韩毛片免费在线观看 | 国产一有一级毛片视频 | 国内自拍在线 | 欧美aaaaaaaaa| 精品中文字幕在线观看 | 亚洲精品久久玖玖玖玖 | 男人天堂网在线观看 | 欧美一级第一免费高清 | 99国产精品久久久久久久日本 | 三级国产在线观看 | 亚洲视频免费 | 欧美成人免费高清视频 | 国产浮力第一页草草影院 | 91精品欧美一区二区三区 | 加勒比色综合 | 精品国产91在线网 | 国产精品自拍第一页 | 一二三中文乱码亚洲乱码 | 久久视频6免费观看视频精品 | 国产成人盗拍精品免费视频 | 欧美性极品hd高清视频 | 国产美女一区二区 | 免费人成在线观看播放国产 | 国产免费爱在线观看视频 | 欧美高清在线精品一区 | 另类zoofilia杂交videos | 日本一视频一区视频二区 | 人成在线免费视频 | 欧美日韩精品免费一区二区三区 | 久草在线首页 | 特级aa毛片在线播放 | 日本一级~片免费永久 | 男女视频在线观看免费高清观看 | 久久亚洲国产精品 | 国产精品久久久久无码av | 久久精品国产亚洲a | 亚洲综合自拍 | 欧美成人xxx | 久久生活片 | 免费人成年短视频在线观看网站 | 特级aaaaaaaaa毛片免费视频 |