django中log的使用

更新时间:2023-06-14 17:00:41 阅读: 评论:0

2.1 middleware.py
# middleware.py
# 这⾥加了⼀个中间件,还要再tting.py中注册⼀下,具体代码⾃⼰百度
import uuid
import json
import threading
import logging
from django import http
from django.utils.deprecation import MiddlewareMixin
from rest_framework import respon as rest_respon
logger = Logger(__name__)
local = threading.local()    # 获取当前线程对象
class RequestLogFilter(logging.Filter):
"""
⽇志过滤器,将当前请求线程的request信息保存到⽇志的record上下⽂
冒险少年
record带有formater需要的信息。
"""
def filter(lf, record):
try:
record.name = record.name.split('.')[-1]
except:
额头高的女人
pass
return True
class WechatyApiMiddleware(MiddlewareMixin):
def process_request(lf, request, **kwargs):
""" 该⽅法在请求到来的时候调⽤请求参数写⼊⽇志 """
# 以下逻辑是实现请求进来打印相关请求参数
body = request.body.decode()
if body:
try:
body = json.loads(body)
except:
pass
request_info = {
'method': hod,
'path':  request.path_info,
'params': request.GET.dict(),
'body': body
}
logger.info(f'requests: {json.dumps(request_info, ensure_ascii=Fal)}')
def process_respon(lf, request, respon):
作文《我的烦恼》"""
优美文段100字
在执⾏完View函数准备将响应发到客户端前被执⾏ / 响应结果写⼊⽇志
这⾥是打印响应数据的⽇志,多加了⼏个 if 判断
"""
path = request.path_info
if isinstance(respon, rest_respon.Respon) or isinstance(respon, http.JsonRespon):            t and path not in filter_path:
logger.info(f'respon: {t.decode("utf-8")}')
elif isinstance(respon, http.HttpResponNotFound):
# 资源不存在
error_data = {
英语元音和辅音的口诀表'status': 'error',
'message': f'not found "{path}"'
登山电影}
<(json.dumps(error_data, ensure_ascii=Fal))转经筒怎么转
踢足球用英语怎么说

本文发布于:2023-06-14 17:00:41,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/89/1038360.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:请求   响应   线程   打印   信息   进来
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图