自定义Django rest_framework中response的示例

在实际项目开发中,原有框架的response可能并不能完全满足我们的需求。比如我们需要定义一些更加详细的RESULT_CODE来说明情况。那么我们就可以基于原有的response进行自定义。

下面是一个自定义Django rest_framework中response的示例

python 复制代码
# -*- coding:utf-8 -*-
import json
from rest_framework.response import Response
from rest_framework.status import HTTP_403_FORBIDDEN, HTTP_404_NOT_FOUND, HTTP_401_UNAUTHORIZED, \
    HTTP_402_PAYMENT_REQUIRED, HTTP_400_BAD_REQUEST, HTTP_500_INTERNAL_SERVER_ERROR, HTTP_200_OK
from rest_framework.pagination import PageNumberPagination

RESPONSE_STATUS = [200, 400, 401, 403, 404, 500]
RESULT_CODE_DICT = {
    200: {
        '0': '成功',
    },
    400: {
        '10000': '请求参数无效',
        '10001': '资源存在,无需重复创建',
        '10002': '参数缺失',
    },
    401: {
        '10100': '用户需要登录:Token无效或缺失',
        '10101': '用户冻结',
        '10102': 'Token无效',
        '10103': 'Token缺失',
        '10104': 'Authentication Key无效',
        '10105': 'Token过期'
    },
    403: {
        '10300': '没有权限访问',
        '10301': '权限密钥无效',
    },
    404: {
        '10400': '所请求的资源不存在'
    },
    500: {
        '10500': '系统错误'
    }
}


# 基于rest_framework的Response
def api_success(data=None, message='', headers=None):
    if not message:
        message = '成功'
    return Response(
        {'result': True, 'result_code': '0', 'result_text': str(message), "message": str(message), 'data': data},
        status=HTTP_200_OK, headers=headers)


def api_bad_request(message=''):
    if not message:
        message = '请求参数有误'
    return Response({'result': False, 'result_code': '10000', 'result_text': str(message), "message": str(message)},
                    status=HTTP_400_BAD_REQUEST)


def api_request_params_required(params):
    if not params:
        message = '检查请求参数是否完整'
    else:
        if isinstance(params, str):
            params = (params,)
        message = '参数:{}为必填'.format(','.join(params))
    return Response({'result': False, 'result_code': '10002', 'result_text': str(message), "message": str(message)},
                    status=HTTP_400_BAD_REQUEST)


def api_repeated_request(message=''):
    if not message:
        message = '资源存在,无需重复创建'
    return Response({'result': False, 'result_code': '10001', 'result_text': str(message), "message": str(message)},
                    status=HTTP_400_BAD_REQUEST)


def api_unauthorized(message=''):
    if not message:
        message = '用户登录验证失败'
    return Response({'result': False, 'result_code': '10100', 'result_text': str(message), "message": str(message)},
                    status=HTTP_401_UNAUTHORIZED)


def api_invalid_authentication_key(message=''):
    if not message:
        message = 'Authentication Key无效'
    return Response({'result': False, 'result_code': '10104', 'result_text': str(message), "message": str(message)},
                    status=HTTP_401_UNAUTHORIZED)


def api_authentication_expired(message=''):
    if not message:
        message = 'Token过期'
    return Response({'result': False, 'result_code': '10105', 'result_text': str(message), "message": str(message)},
                    status=HTTP_401_UNAUTHORIZED)


def api_suspended(message=''):
    if not message:
        message = '用户冻结'
    return Response({'result': False, 'result_code': '10101', 'result_text': str(message), "message": str(message)},
                    status=HTTP_401_UNAUTHORIZED)


def api_permissions_required(permissions=None):
    if not permissions:
        message = '没有权限访问'
    else:
        if isinstance(permissions, str):
            permissions = (permissions,)
        message = '缺失权限:{}'.format(','.join(permissions))
    return Response({'result': False, 'result_code': '10300', 'result_text': str(message), "message": str(message)},
                    status=HTTP_403_FORBIDDEN)


def api_invalid_permission_key(message=''):
    if not message:
        message = '权限验证失败'
    return Response({'result': False, 'result_code': '10301', 'result_text': str(message), "message": str(message)},
                    status=HTTP_403_FORBIDDEN)


def api_not_found(message=''):
    if not message:
        message = '所请求的资源不存在'
    return Response({'result': False, 'result_code': '10400', 'result_text': str(message), "message": str(message)},
                    status=HTTP_404_NOT_FOUND)


def api_error(message=''):
    if not message:
        message = '系统错误'
    return Response({'result': False, 'result_code': '10500', 'result_text': str(message), "message": str(message)},
                    status=HTTP_500_INTERNAL_SERVER_ERROR)


def build_pagination_response(request, queryset, serializer_class):
    data, headers = build_pagination_queryset_data(request, queryset, serializer_class)
    return api_success(data=data, headers=headers)


def build_pagination_queryset_data(request, queryset, serializer_class):
    """
    为分页接口返回的headers中自定义一些信息
    :param request:
    :param queryset:
    :param serializer_class:
    :return:
    """
    page = request.GET.get('page', None)
    page_size = request.GET.get('page_size', None)
    total = len(queryset)
    headers = None
    if page and page_size:
        paginator = PageNumberPagination()
        paginator.page_size_query_param = 'page_size'
        queryset = paginator.paginate_queryset(queryset, request)
        pagination_params = json.dumps({'total': total, 'page': int(page), 'page_size': int(page_size)})
        headers = {'X-Pagination': pagination_params,
                   'Access-Control-Expose-Headers': 'X-Pagination'}
    data = serializer_class(queryset, many=True).data
    return data, headers
相关推荐
shengli7221 分钟前
机器学习与人工智能
jvm·数据库·python
2301_765703149 分钟前
Python迭代器(Iterator)揭秘:for循环背后的故事
jvm·数据库·python
怪兽源码27 分钟前
基于SpringBoot的选课调查系统
java·spring boot·后端·选课调查系统
追风少年ii29 分钟前
多组学扩展---分子对接pyrosetta
python·数据分析·空间·单细胞
2301_821369611 小时前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
m0_561359671 小时前
使用Kivy开发跨平台的移动应用
jvm·数据库·python
csdn_aspnet1 小时前
ASP.NET Core 中的依赖注入
后端·asp.net·di·.net core
编程火箭车1 小时前
04.第一个 Python 程序:Hello World 从编写到运行全解析
python·python第一个程序·python入门报错解决·python新手教程·hello world 程序·python终端运行·pycharm运行代码
qq_423233902 小时前
如何用FastAPI构建高性能的现代API
jvm·数据库·python
昊坤说不出的梦2 小时前
【实战】监控上下文切换及其优化方案
java·后端