日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

django日志默認(rèn)打印request請(qǐng)求信息的方法示例

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

需求

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

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

舊的解決辦法

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

django日志默認(rèn)打印request請(qǐng)求信息的方法示例

新的解決方案

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

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

Loggers Handlers Filters Formatters

2、django中間件存儲(chǔ)request信息。

class RequestLogMiddleware(MiddlewareMixin): ''' 將request的信息記錄在當(dāng)前的請(qǐng)求線程上 ''' 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): ''' 日志過(guò)濾器,將當(dāng)前請(qǐng)求線程的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、實(shí)現(xiàn)原理及代碼

通過(guò) 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): ''' 日志過(guò)濾器,將當(dāng)前請(qǐng)求線程的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的信息記錄在當(dāng)前的請(qǐng)求線程上。 ''' 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’ #使用該中間件 #將當(dāng)前的request信息保存到當(dāng)前線程供日志打印使用]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’: { #該格式化中包含有過(guò)濾器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’: { #注冊(cè)該過(guò)濾器 ’request_info’: {’()’: ’wcloud.middleware-waiwen.RequestLogFilter’} }, ’handlers’: { ’log’: {’level’: ’DEBUG’,’class’: ’logging.StreamHandler’,’formatter’: ’custom’, #在該過(guò)handler中使用該過(guò)濾器’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日志默認(rèn)打印request請(qǐng)求信息的方法示例

參考:

給Django日志加上request_id

總結(jié)

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

標(biāo)簽: django request
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
jiujiure精品视频播放| 国产亚洲在线观看| 欧美一级二区| 日韩中文一区二区| 啪啪亚洲精品| 国产精品日韩精品中文字幕| 国产精品jk白丝蜜臀av小说| 国产精品任我爽爆在线播放 | 中文在线а√天堂| 在线天堂资源www在线污| 精品国产一区二区三区av片| 中文字幕日本一区| 欧美一区二区三区久久| 蜜桃久久av一区| 在线看片不卡| 中文字幕色婷婷在线视频| 亚洲天堂av资源在线观看| 激情视频网站在线播放色| 91精品国产经典在线观看 | 中文在线一区| 五月综合激情| 香蕉国产精品| 91精品国产乱码久久久久久久 | 精品久久福利| а√天堂8资源中文在线| 快播电影网址老女人久久| 午夜久久美女| 婷婷视频一区二区三区| 综合一区在线| 青青伊人久久| 牛牛精品成人免费视频| 国产精品国码视频| 超碰在线99| 欧美 日韩 国产一区二区在线视频 | 国产精品日本一区二区三区在线| 国际精品欧美精品| 免费久久久久久久久| 日韩欧美中文在线观看| 久久99久久久精品欧美| 青青久久av| 亚洲视频电影在线| 久久精品国产福利| 美女网站一区| 欧美日韩亚洲国产精品| 久久精品色播| 婷婷综合亚洲| 国产亚洲欧美日韩在线观看一区二区| 精品中国亚洲| 日韩一级网站| 国产高清亚洲| 欧美福利专区| 国产精品qvod| 在线亚洲免费| 国产精品成人一区二区网站软件| 欧美va天堂| 精品亚洲美女网站| 亚洲精品国产日韩| 日本在线啊啊| 91午夜精品| 天堂√8在线中文| 天堂久久av| 欧美日韩视频免费观看| 午夜精品福利影院| 丝袜美腿一区| 国产伦精品一区二区三区在线播放| 91精品一区国产高清在线gif| 蜜桃一区二区三区在线| av日韩中文| 欧美日韩亚洲一区在线观看| 99亚洲视频| 国产高清不卡| 国产精品亚洲欧美日韩一区在线| 亚洲国产一区二区三区在线播放| 麻豆精品久久久| 日韩在线a电影| 999精品色在线播放| 国产精品www.| 亚洲精品亚洲人成在线观看| 欧美精品一区二区久久| 成人污污视频| 国产亚洲欧美日韩在线观看一区二区| 黑丝美女一区二区| 国产精品久久观看| 日本va欧美va欧美va精品| 久久国产电影| 国产精选在线| 国产精品一区二区三区av麻| 久热re这里精品视频在线6| 亚洲涩涩在线| 97久久亚洲| 美女精品在线观看| 欧美福利在线| 欧美羞羞视频| 精品视频在线你懂得| 日韩精品一区二区三区免费视频| 99在线观看免费视频精品观看| 国产91欧美| 国产精品麻豆成人av电影艾秋 | 涩涩涩久久久成人精品| 国产精品88久久久久久| 日韩电影免费在线观看| 欧美黑人巨大videos精品| 视频精品一区二区| 午夜精品免费| 91久久久精品国产| 久久精品播放| 日韩在线不卡| 国产欧美一区二区三区精品酒店| 精品国产中文字幕第一页| 国产精品毛片久久久| 欧美一级二级三级视频| 日韩精品一区二区三区中文在线 | 欧美国产精品| 国产精品美女久久久久久不卡| 免费观看在线综合| 中文一区二区| 国产精品美女| 在线一区欧美| 香蕉久久夜色精品国产| 麻豆成人在线| 亚洲午夜免费| 日韩美女国产精品| 日本不卡在线视频| 亚洲资源网站| 免费不卡在线视频| 中文字幕一区日韩精品| 亚洲永久精品唐人导航网址| 亚洲三级精品| 日韩精品成人在线观看| 亚洲1区在线观看| 日韩中文字幕| 欧美日韩一区二区国产 | 日韩在线精品| 亚洲成人精品| 亚洲精品午夜av福利久久蜜桃| 欧美日韩在线网站| 午夜欧美精品久久久久久久| 亚洲欧美日韩国产一区二区| 亚洲在线观看| 亚洲欧洲美洲国产香蕉| 91亚洲精品在看在线观看高清| 国产欧美高清| 国产精品tv| 不卡一二三区| 五月天综合网站| 综合色就爱涩涩涩综合婷婷| 日本成人在线视频网站| 国产精品免费不| 一区二区精品伦理...| 99久久亚洲精品蜜臀| 亚洲一区欧美二区| 日本a口亚洲| 成人亚洲一区二区| 美女毛片一区二区三区四区| 蜜臀久久精品| 一区二区三区四区日韩| 精品一区二区三区四区五区| 日韩成人三级| 精品在线91| 中文字幕av一区二区三区人| 国产乱人伦丫前精品视频| 国产aa精品| 国产婷婷精品| 国产欧美亚洲一区| 欧洲av不卡| 免费欧美在线视频| 国产精品久久久久久模特| 欧美日韩国产观看视频| 在线视频精品| 国产精品中文字幕亚洲欧美| 在线中文字幕播放| 久久亚洲风情| 久久99精品久久久久久园产越南| 日韩欧美一区免费| 热久久免费视频| 精品亚洲a∨| 日韩在线一区二区| 成人在线黄色| 三级亚洲高清视频| 麻豆视频久久| 一区在线视频观看| 国产欧美日韩在线一区二区| 99久久99久久精品国产片果冰| 日韩一区精品| 免费在线小视频| 日韩毛片网站| 亚洲网站视频| 欧美一区91| 亚洲第一精品影视| 国产精品密蕾丝视频下载| 黄色日韩在线| 在线精品一区| 亚洲国产日韩欧美在线| 国产精品一区二区中文字幕| 亚洲午夜久久久久久尤物| 国产精品伊人| 性一交一乱一区二区洋洋av| 精品国产乱码久久久| 视频一区中文字幕| 久久久一本精品|