前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Flask 学习-57.Flask-RESTX 定制返回统一的JSON格式

Flask 学习-57.Flask-RESTX 定制返回统一的JSON格式

作者头像
上海-悠悠
发布2022-09-13 15:45:30
7630
发布2022-09-13 15:45:30
举报

前言

一般在接口开发中,会定制统一的返回JSON 格式如:{‘code’: 0, ‘message’: ‘success’, ‘data’: {}}

定制JSON 格式

Flask-RESTX  的Api对象提供了一个representation的装饰器,允许定制返回数据的呈现格式

基本示例

代码语言:javascript
复制
api = Api(app)

@api.representation('application/json')
def output_json(data, code, headers):
    # TODO ..... 添加自定义处理
    return resp

flask_restful.representations.py文件源码中有一个output_json 方法

代码语言:javascript
复制
def output_json(data, code, headers=None):
    """Makes a Flask response with a JSON encoded body"""

    settings = current_app.config.get("RESTX_JSON", {})

    # If we're in debug mode, and the indent is not set, we set it to a
    # reasonable value here.  Note that this won't override any existing value
    # that was set.
    if current_app.debug:
        settings.setdefault("indent", 4)

    # always end the json dumps with a new line
    # see https://github.com/mitsuhiko/flask/pull/1262
    dumped = dumps(data, **settings) + "\n"

    resp = make_response(dumped, code)
    resp.headers.extend(headers or {})
    return resp

于是在代码中使用@api.representation() 重新定义输出格式

代码语言:javascript
复制
from six import PY3

@api.representation('application/json')  # 指定响应形式对应的转换函数
def output_json(data, code, headers=None):
    """自定义json形式"""
    # 根据flask内置配置, 进行格式处理(缩进/key是否排序等)
    settings = current_app.config.get('RESTX_JSON', {})

    if current_app.debug:
        settings.setdefault('indent', 4)
        settings.setdefault('sort_keys', not PY3)

    # *****------start---------此处是新增代码---------********
    if 'message' not in data:  # 判断是否设置了自定义的错误信息
        data = {
            'code': 0,
            'message': 'success',
            'data': data
        }
    # *****-------end--------此处是新增代码---------********
    # 字典转json字符串
    dumped = dumps(data, **settings) + "\n"

    # 构建响应对象
    resp = make_response(dumped, code)
    resp.headers.extend(headers or {})
    return resp

完整示例代码

以下是完整的示例

代码语言:javascript
复制
from json import dumps
from flask import Flask, current_app, make_response, Response
from flask_restx import Resource, Api
from six import PY3

app = Flask(__name__)
api = Api(app)

@api.representation('application/json')  # 指定响应形式对应的转换函数
def output_json(data, code, headers=None):
    """自定义json形式"""
    # 根据flask内置配置, 进行格式处理(缩进/key是否排序等)
    settings = current_app.config.get('REST_JSON', {})

    if current_app.debug:
        settings.setdefault('indent', 4)
        settings.setdefault('sort_keys', not PY3)

    # *****------start---------此处是新增代码---------********
    if 'message' not in data:  # 判断是否设置了自定义的错误信息
        data = {
            'code': 0,
            'message': 'success',
            'data': data
        }
    # *****-------end--------此处是新增代码---------********
    # 字典转json字符串
    dumped = dumps(data, **settings) + "\n"

    # 构建响应对象
    resp = make_response(dumped, code)
    resp.headers.extend(headers or {})
    return resp

@api.route('/demo')
class DemoResource(Resource):

    def get(self):
        return {'id': "1"}

    def post(self):
        return {'message': 'success', "data": None}

if __name__ == '__main__':
    app.run()

测试get请求

2022年第 12期《python接口web自动化+测试开发》课程,9月17号开学!

本期上课时间:2022年9月17号 - 2022年12月17号,周六周日上午9:00-11:00

报名费:报名费3000一人(周期3个月)

联系微信/QQ:283340479

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-09-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 从零开始学自动化测试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 定制JSON 格式
  • 完整示例代码
    • 报名费:报名费3000一人(周期3个月)
      • 联系微信/QQ:283340479
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档