drf自定义异常处理

一、前言

​ 我们知道当前端传递到后端的数据不正确时,后端会将错误的信息返回到前端。如果我们后端服务器出现了异常,那就说明我们的后端逻辑出现了问题,需要对后端代码进行修改。

​ 我们需要在异常发生时,对异常进行捕获,并记录到日志文件当中,而不是将错误的信息直接返回到前端,这是没有意义的。那么我们如何来自定义自己的异常处理机制呢?

二、drf默认异常处理

rest_framework文件下的views.py中exception_handler方法

def exception_handler(exc, context):
    if isinstance(exc, Http404):
        exc = exceptions.NotFound()
    elif isinstance(exc, PermissionDenied):
        exc = exceptions.PermissionDenied()

    if isinstance(exc, exceptions.APIException):
        headers = {}
        if getattr(exc, 'auth_header', None):
            headers['WWW-Authenticate'] = exc.auth_header
        if getattr(exc, 'wait', None):
            headers['Retry-After'] = '%d' % exc.wait

        if isinstance(exc.detail, (list, dict)):
            data = exc.detail
        else:
            data = {'detail': exc.detail}

        set_rollback()
        return Response(data, status=exc.status_code, headers=headers)
	
    # 当exe不是APIException的实例时会返回None,导致了500错误。
    return None

三、借用drf的异常处理来自定义

exception.py
from rest_framework.views import exception_handler
from rest_framework.response import Response


def my_exception_handler(exe, context):
    response = exception_handler(exe, context)
    if not response:
        # 此处对异常信息进行日志保存
        response = Response({'detail': '服务器异常,%s' % exe},status=500)
    return response

四、修改配置文件

settings.py
REST_FRAMEWORK = {
    # 默认异常处理
    # 'EXCEPTION_HANDLER': 'rest_framework.views.exception_handler',
    
    'EXCEPTION_HANDLER': 'api.exception.my_exception_handler',
}
posted @ 2020-02-25 19:01  GhostAnt  阅读(677)  评论(0编辑  收藏  举报