标签:exception errors 自定义 rest response result 异常 Response drf
1,在项目的utils目录中,创建 exception.py :
from rest_framework.views import exception_handler from rest_framework.response import Response def custom_exception_handler(exc, context): response = exception_handler(exc, context) if response: detail = response.data.get('detail') non_field_errors = response.data.get('non_field_errors') # 异常响应 if detail: #判断异常类型 return Response({'status': 2, 'msg': detail, 'result': {}}) elif non_field_errors: return Response({'status': 1, 'msg': non_field_errors[0], 'result': {}}) else: # return Response({'response': '接口参数错误', 'result': {}, 'code': '', 'tips': response.data}) return Response({'status': 5, 'msg': '接口参数错误', 'result': {}, 'tips': response.data})
2,在项目的settings.py 文件中,添加至全局:
REST_FRAMEWORK = { 'EXCEPTION_HANDLER': 'utils.exception.custom_exception_handler', # 自定义异常处理 # 分页 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination', 'PAGE_SIZE': 5, # 查询,过滤 'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',), }
3,结束!
标签:exception,errors,自定义,rest,response,result,异常,Response,drf 来源: https://www.cnblogs.com/noteaddr/p/12937093.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。