电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:10日期: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
相關文章:
主站蜘蛛池模板: 定制/定做衬衫厂家/公司-衬衫订做/订制价格/费用-北京圣达信 | 天津仓库出租网-天津电商仓库-天津云仓一件代发-【博程云仓】 | 上海道勤塑化有限公司 | 仓储货架_南京货架_钢制托盘_仓储笼_隔离网_环球零件盒_诺力液压车_货架-南京一品仓储设备制造公司 | 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 | 焊管生产线_焊管机组_轧辊模具_焊管设备_焊管设备厂家_石家庄翔昱机械 | STRO|DTRO-STRO反渗透膜(科普)_碟滤 | 手持气象站_便携式气象站_农业气象站_负氧离子监测站-山东万象环境 | 家德利门业,家居安全门,别墅大门 - 安徽家德利门业有限公司 | SPC工作站-连杆综合检具-表盘气动量仪-内孔缺陷检测仪-杭州朗多检测仪器有限公司 | 接地电阻测试仪[厂家直销]_电缆故障测试仪[精准定位]_耐压测试仪-武汉南电至诚电力设备 | 智能交通网_智能交通系统_ITS_交通监控_卫星导航_智能交通行业 | 变色龙云 - 打包app_原生app_在线制作平台_短链接_ip查询 | 选宝石船-陆地水上开采「精选」色选机械设备-青州冠诚重工机械有限公司 | HYDAC过滤器,HYDAC滤芯,现货ATOS油泵,ATOS比例阀-东莞市广联自动化科技有限公司 | 电动高尔夫球车|电动观光车|电动巡逻车|电动越野车厂家-绿友机械集团股份有限公司 | 郑州爱婴幼师学校_专业幼师培训_托育师培训_幼儿教育培训学校 | 轴流风机-鼓风机-离心风机-散热风扇-罩极电机,生产厂家-首肯电子 | 中央空调维修、中央空调保养、螺杆压缩机维修-苏州东菱空调 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 圆窗水平仪|伊莉莎冈特elesa+ganter| 二手色谱仪器,十万分之一分析天平,蒸发光检测器,电位滴定仪-湖北捷岛科学仪器有限公司 | 蒸压釜_蒸养釜_蒸压釜厂家-山东鑫泰鑫智能装备有限公司 | 耐火浇注料-喷涂料-浇注料生产厂家_郑州市元领耐火材料有限公司 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 上海律师事务所_上海刑事律师免费咨询平台-煊宏律师事务所 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 上海防爆真空干燥箱-上海防爆冷库-上海防爆冷柜?-上海浦下防爆设备厂家? | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 周口风机|周风风机|河南省周口通用风机厂 | 国际金融网_每日财经新资讯网 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 圈酒招商网【jiushuitv.com】_酒水招商_代理_加盟平台 | 云杂志网-学术期刊-首页 | 全自动端子机|刺破式端子压接机|全自动双头沾锡机|全自动插胶壳端子机-东莞市傅氏兄弟机械设备有限公司 | 卫生人才网-中国专业的医疗卫生医学人才网招聘网站! | 济南品牌包装设计公司_济南VI标志设计公司_山东锐尚文化传播 | 冷藏车-东风吸污车-纯电动环卫车-污水净化车-应急特勤保障车-程力专汽厂家-程力专用汽车股份有限公司销售二十一分公司 | 欧洲MV日韩MV国产_人妻无码一区二区三区免费_少妇被 到高潮喷出白浆av_精品少妇自慰到喷水AV网站 | Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | 电动卫生级调节阀,电动防爆球阀,电动软密封蝶阀,气动高压球阀,气动对夹蝶阀,气动V型调节球阀-上海川沪阀门有限公司 | 光泽度计_测量显微镜_苏州压力仪_苏州扭力板手维修-苏州日升精密仪器有限公司 |