【发布时间】:2018-07-23 07:01:09
【问题描述】:
我想这更像是一个代码质量问题,但它确实涉及处理未处理的异常是 Django REST 框架。
删除受保护的记录只返回<h1>500 internal server error<h1>
所以我添加了示例自定义异常处理程序。第一行返回一个无响应。
response = exception_handler(exc, context)
from rest_framework.views import exception_handler
from rest_framework.response import Response
from rest_framework import status
def custom_exception_handler(exc, context):
response = exception_handler(exc, context)
if response is None:
#DRF could not process the exception so we will treat it as a 500 and try to get the user as much info as possible.
response = Response({'error': str(exc)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
return response
所以在这种情况下,我将其视为 500,因为 DRF 无法处理 exc。
我想我的问题是这是一种适当的处理方式吗?有没有人有这方面的经验有更好的解决方案?
更新:
Traceback:
File "/usr/local/lib/python3.6/site-packages/django/core/handlers/exception.py" in inner
34. response = get_response(request)
File "/usr/local/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
115. response = self.process_exception_by_middleware(e, request)
File "/usr/local/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
113. response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/usr/local/lib/python3.6/site-packages/django/views/decorators/csrf.py" in wrapped_view
54. return view_func(*args, **kwargs)
File "/usr/local/lib/python3.6/site-packages/rest_framework/viewsets.py" in view
116. return self.dispatch(request, *args, **kwargs)
File "/usr/local/lib/python3.6/site-packages/rest_framework/views.py" in dispatch
495. response = self.handle_exception(exc)
File "/usr/local/lib/python3.6/site-packages/rest_framework/views.py" in handle_exception
455. self.raise_uncaught_exception(exc)
File "/usr/local/lib/python3.6/site-packages/rest_framework/views.py" in dispatch
492. response = handler(request, *args, **kwargs)
File "/usr/local/lib/python3.6/site-packages/rest_framework/mixins.py" in create
21. self.perform_create(serializer)
File "/device_mgmt/selection/views.py" in perform_create
84. serializer.save(realm=utils.get_realm_from_request(self.request))
File "/usr/local/lib/python3.6/site-packages/rest_framework/serializers.py" in save
214. self.instance = self.create(validated_data)
File "/usr/local/lib/python3.6/site-packages/rest_framework/serializers.py" in create
943. instance = ModelClass._default_manager.create(**validated_data)
File "/usr/local/lib/python3.6/site-packages/django/db/models/manager.py" in manager_method
82. return getattr(self.get_queryset(), name)(*args, **kwargs)
File "/usr/local/lib/python3.6/site-packages/django/db/models/query.py" in create
422. obj.save(force_insert=True, using=self.db)
File "/device_mgmt/selection/models.py" in save
123. self.full_clean()
File "/usr/local/lib/python3.6/site-packages/django/db/models/base.py" in full_clean
1203. raise ValidationError(errors)
Exception Type: ValidationError at /company/api/company/
Exception Value: {'id': ['Company with this Id already exists.']}
Django 模型抛出验证错误,但其余框架视图将其称为未捕获。
【问题讨论】:
标签: django exception django-rest-framework