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

2024-06-10 20:52

本文主要是介绍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, fieldsmodel = 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, **kwargs):return db_get_todo()  # Some function that queries the db
  • 重命名属性
    i.通常,面向公众的字段名称与内部字段名称不同。要配置此映射
    ii.也可以使用匿名函数或者嵌套属性
'address': fields.String,
}
model = {'name': fields.String(attribute=lambda x: x._private_name),'address': fields.String,
}
model = {'name': fields.String(attribute='people_list.0.person_dictionary.name'),'address': fields.String,
}
  • 默认值
model = {'name': fields.String(default='Anonymous User'),'address': fields.String,
}
  • 自定义字段和多个值:适合特定的格式需求
class UrgentItem(fields.Raw):def format(self, value):return "Urgent" if value & 0x01 else "Normal"class UnreadItem(fields.Raw):def format(self, value):return "Unread" if value & 0x02 else "Read"model = {'name': fields.String,'priority': UrgentItem(attribute='flags'),'status': UnreadItem(attribute='flags'),
}
  • Url 和其他具体字段
model = {'name': fields.String,'uri': fields.Url('', absolute=True), // 能返回当前访问的url,absolute参数可以返回完整的url
}
  • 复杂结构
    i.marshal() 将一个平面结构的 data 转换成复杂结构
from flask_restx import fields, marshal
import json
resource_fields = {'name': fields.String,'address': {'line 1': fields.String(attribute='addr1'),'line 2': fields.String(attribute='addr2'),'city': fields.String,'state': fields.String,'zip': fields.String}
}@api.route('/test')
class testMarshal(Resource):def post(self):data = {'name': 'bob', 'addr1': '123 fake street', 'addr2': '', 'city': 'New York', 'state': 'NY', 'zip': '10468'}return marshal(data, resource_fields)
  • 通配符字段
    i.只关心值的类型,不关心key的名称时,使用 Wildcard 构建。
    ii.注意这里不是正则表达式,只能简单使用 * 和 ?。
>>> from flask_restx import fields, marshal
>>> import json
>>>
>>> wild = fields.Wildcard(fields.String)
>>> wildcard_fields = {'*': wild}
>>> data = {'John': 12, 'bob': 42, 'Jane': '68'}
>>> json.dumps(marshal(data, wildcard_fields))
>>> '{"Jane": "68", "bob": "42", "John": "12"}'>>> wildcard_fields = {'j*': wild}
>>> data = {'John': 12, 'bob': 42, 'Jane': '68'}
>>> json.dumps(marshal(data, wildcard_fields))
>>> '{"Jane": "68", "John": "12"}'

这篇关于Flask-REXTx 学习笔记——1.响应编组(Response marshalling)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1049244

相关文章

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

如何解决Spring MVC中响应乱码问题

《如何解决SpringMVC中响应乱码问题》:本文主要介绍如何解决SpringMVC中响应乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC最新响应中乱码解决方式以前的解决办法这是比较通用的一种方法总结Spring MVC最新响应中乱码解

Flask 验证码自动生成的实现示例

《Flask验证码自动生成的实现示例》本文主要介绍了Flask验证码自动生成的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 目录生成图片以及结果处理验证码蓝图html页面展示想必验证码大家都有所了解,但是可以自己定义图片验证码

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Flask解决指定端口无法生效问题

《Flask解决指定端口无法生效问题》文章讲述了在使用PyCharm开发Flask应用时,启动地址与手动指定的IP端口不一致的问题,通过修改PyCharm的运行配置,将Flask项目的运行模式从Fla... 目录android问题重现解决方案问题重现手动指定的IP端口是app.run(host='0.0.

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

springMVC返回Http响应的实现

《springMVC返回Http响应的实现》本文主要介绍了在SpringBoot中使用@Controller、@ResponseBody和@RestController注解进行HTTP响应返回的方法,... 目录一、返回页面二、@Controller和@ResponseBody与RestController

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操