Flask-REXTx 学习笔记——1.响应编组(Response marshalling)

记录对Flask-REXTx的学习笔记

简介

  • Flask-RESTx是一个基于Flask的扩展,它提供了一些额外的功能来帮助开发人员更轻松地构建强大的RESTful API。这些功能包括API文档的自动生成、请求参数解析和API资源管理等。Flask-RESTx的目标是在维护API时能够提供更好的文档和工具支持。
  • 它是Flask-RESTful的增强版(实际上是因为lask-RESTful的开发者在GitHub上迟迟不处理BUG和优化,所以有人做了一个分支开发了Flask-RESTx),完全兼容Flask-RESTPlus,提供了更规范化的接口编写方式,并支持Swagger文档,这使得API的设计和文档化更加清晰和简便。

用 Flask-RESTx 还是蓝图 blueprint?

  • 我的项目之前是用蓝图来构建和组织后端结构的,但是它缺少RESTful API的某些特定支持,例如基于Swagger的接口文档自动生成。
  • 随着项目体量增大,不便于开发人员查阅和参考,也没有可供调试的接口。最重要的是,新人没有一个快速入手的文档以供查询,基本都靠口口相传。
  • 加上虽然我们的后端设计思想是符合 RESTful AIP的,但是API 文档也是它的一个重要部分。
  • 所以基于以上原因,决定引入 Flask-RESTx。之后新内容用 Flask-RESTx,旧内容依旧用蓝图,目前不改动。

响应编组(Response marshalling)

  • 基本用法:
    i.api.model + api.marshal_with(model, envelope)
    ii.envelope 会将输出按对应参数进行一层字典包装
from flask_restx import Resource, fields

model = api.model('Model', {
   
    'name': fields.String,
    'address': fields.String,
    'date_updated': fields.DateTime(dt_format='rfc822'),
})

@api.route('/todo')
class Todo(Resource):
    @api.marshal_with(model, envelope='resource') // 这里的最终输出变成 {
   'resource': db_get_todo()}
    def get(self, 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值