Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/logging/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在Django Rest框架中记录4XX Http状态的请求和响应?_Django_Logging_Django Rest Framework_Django Logging - Fatal编程技术网

如何在Django Rest框架中记录4XX Http状态的请求和响应?

如何在Django Rest框架中记录4XX Http状态的请求和响应?,django,logging,django-rest-framework,django-logging,Django,Logging,Django Rest Framework,Django Logging,DRF的默认行为是为5XX抛出异常,但为4XX返回包含错误详细信息的有效响应。我想记录4XX失败的任何API调用的请求和响应 当前日志仅显示错误请求:/path/api/ 回答:自定义异常工作正常。您可以定义自己的自定义异常处理程序并访问您的请求,例如: 来自rest\u framework.views导入异常\u处理程序 def自定义异常处理程序(exc,上下文): 响应=异常处理程序(exc) 如果响应不是无: response.data['status\u code']=response.

DRF的默认行为是为5XX抛出异常,但为4XX返回包含错误详细信息的有效响应。我想记录4XX失败的任何API调用的请求和响应

当前日志仅显示
错误请求:/path/api/


回答:自定义异常工作正常。

您可以定义自己的自定义异常处理程序并访问您的请求,例如:

来自rest\u framework.views导入异常\u处理程序
def自定义异常处理程序(exc,上下文):
响应=异常处理程序(exc)
如果响应不是无:
response.data['status\u code']=response.status\u code
response.data['request']=上下文['request']
返回响应
并在
settings.py
中显示自定义处理程序,例如:

REST\u框架={
“异常处理程序”:“我的项目。我的应用程序。utils。自定义异常处理程序”
}