将请求记录到django-rest-framework [英] Logging requests to django-rest-framework
问题描述
为了进行调试,我想使用Django的日志记录机制来记录每个传入的请求,当它到达django-rest-framework的门口时。
For debugging purposes, I would like to use Django's logging mechanism to log each and every incoming request when it "arrives" at django-rest-framework's doorstep.
Djagno按以下方式(从settings.py中的LOGGING部分)提供其请求的日志记录(仅警告日志级别及以上)):
Djagno offers logging of its requests (only "warning" log level and above) in the following manner (from LOGGING section in settings.py):
'django.request': {
'handlers': ['mail_admins'],
'level': 'ERROR',
'propagate': False,
},
我正在寻找这样的东西(注意:日志级别是DEBUG):
I'm looking to achieve something like this (notice: log level is DEBUG):
'rest_framework.request': {
'handlers': ['logfile'],
'level': 'DEBUG',
'propagate': False,
},
有没有办法可以将没有将记录器嵌入DRF的源代码?
有可能是某种记录后端 DRF中的选项我不知道?
Is there a way I can do that without embedding a logger in to DRF's source code?
Is there maybe some sort of "Logging Backend" option in DRF I'm not aware of?
推荐答案
我做了一个通用的 RequestLogMiddleware
可以使用 decorator_from_middleware
挂钩到任何Django 查看
。
I made a generic RequestLogMiddleware
that can be hooked into any Django View
using decorator_from_middleware
.
import socket
import time
class RequestLogMiddleware(object):
def process_request(self, request):
request.start_time = time.time()
def process_response(self, request, response):
if response['content-type'] == 'application/json':
if getattr(response, 'streaming', False):
response_body = '<<<Streaming>>>'
else:
response_body = response.content
else:
response_body = '<<<Not JSON>>>'
log_data = {
'user': request.user.pk,
'remote_address': request.META['REMOTE_ADDR'],
'server_hostname': socket.gethostname(),
'request_method': request.method,
'request_path': request.get_full_path(),
'request_body': request.body,
'response_status': response.status_code,
'response_body': response_body,
'run_time': time.time() - request.start_time,
}
# save log_data in some way
return response
request_log / mixins.py
request_log/mixins.py
from django.utils.decorators import decorator_from_middleware
from .middleware import RequestLogMiddleware
class RequestLogViewMixin(object):
"""
Adds RequestLogMiddleware to any Django View by overriding as_view.
"""
@classmethod
def as_view(cls, *args, **kwargs):
view = super(RequestLogViewMixin, cls).as_view(*args, **kwargs)
view = decorator_from_middleware(RequestLogMiddleware)(view)
return view
my_django_rest_api / views.py
my_django_rest_api/views.py
from rest_framework import generics
from ...request_log.mixins import RequestLogViewMixin
class SomeListView(
RequestLogViewMixin,
generics.ListAPIView
):
...
这篇关于将请求记录到django-rest-framework的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!