首页 > Java > java教程 > 正文

Quarkus REST API 返回 JSON 时避免额外的数组包装

花韻仙語
发布: 2025-07-12 16:04:24
原创
198人浏览过

quarkus rest api 返回 json 时避免额外的数组包装

正如摘要所述,本文档旨在解决在使用 Quarkus 构建 REST API 时,由于返回 Multi 类型并指定 APPLICATION_JSON 媒体类型,导致响应被额外数组包装的问题。我们将探讨如何通过使用 @Stream(Stream.MODE.RAW) 注解来避免这种不必要的包装,并理解其对响应格式和数据流处理的影响。

问题描述

在使用 Quarkus 开发 REST API 时,如果使用 Multi 作为返回类型,并指定 APPLICATION_JSON 作为 Produces 的媒体类型,可能会遇到一个问题:即使返回的是有效的 JSON 字符串,Quarkus 也会自动将响应包装在一个额外的数组中。例如,以下代码:

@Path("/testData")
@GET
@Produces(MediaType.APPLICATION_JSON)
public Multi<String> test() throws IOException {
    return Multi.createFrom().items(IOUtils.toString(getClass().getResourceAsStream("/TestJSON.json"), StandardCharsets.UTF_8));
}
登录后复制

如果 /TestJSON.json 文件包含以下 JSON 内容:

{
  "isA": "customerDocument",
  "createdOn": "2022-10-10T12:29:43",
  "customerBody": {
    "customerList": [
      {
        "name": "Batman",
        "age": 45,
        "city": "gotham"
      }
    ]
  }
}
登录后复制

实际返回的响应将会是:

[
  {
    "isA": "customerDocument",
    "createdOn": "2022-10-10T12:29:43",
    "customerBody": {
      "customerList": [
        {
          "name": "Batman",
          "age": 45,
          "city": "gotham"
        }
      ]
    }
  }
]
登录后复制

可以看到,JSON 对象被包裹在一个数组中,这通常不是我们期望的结果。

解决方案

解决这个问题的方法是使用 @Stream(Stream.MODE.RAW) 注解。将该注解添加到 REST API 方法上,可以指示 Resteasy(Quarkus 使用的 REST 实现)直接将每个值写入到输出流,而无需进行任何格式化。

修改后的代码如下:

@Path("/testData")
@GET
@Produces(MediaType.APPLICATION_JSON)
@Stream(Stream.MODE.RAW)
public Multi<String> test() throws IOException {
    return Multi.createFrom().items(IOUtils.toString(getClass().getResourceAsStream("/TestJSON.json"), StandardCharsets.UTF_8));
}
登录后复制

添加 @Stream(Stream.MODE.RAW) 注解后,返回的响应将不再包含额外的数组包装,而是直接返回 /TestJSON.json 文件中的 JSON 内容。

原理解释

根据 Resteasy 的文档,当 REST API 方法没有使用 @Stream 注解时,Resteasy 会收集 Multi 发出的所有值,然后将它们包装到一个 java.util.List 实体中,并将其发送给客户端。这就是为什么响应会被额外的数组包装的原因。

@Stream(Stream.MODE.RAW) 注解改变了这种行为。它指示 Resteasy 直接将每个值写入到输出流,而无需等待 Multi 完成。这不仅避免了额外的数组包装,还可能影响数据的流处理方式。

注意事项

使用 @Stream(Stream.MODE.RAW) 注解时,需要注意以下几点:

  • 数据格式: 确保 Multi 发出的每个值都是有效的 JSON 字符串,因为 Resteasy 不会进行任何格式化。
  • 流处理: @Stream(Stream.MODE.RAW) 注解会改变数据的流处理方式。如果没有该注解,Resteasy 会等待 Multi 完成,然后一次性发送所有数据。使用该注解后,Resteasy 会立即发送每个值。这可能会影响性能,具体取决于数据的生成速度和网络带宽。
  • 适用场景: @Stream(Stream.MODE.RAW) 注解最适合用于处理可以被分割成小块的数据,例如字符串、字节或缓冲区。

总结

通过使用 @Stream(Stream.MODE.RAW) 注解,可以有效地解决 Quarkus REST API 返回 Multi 类型并指定 APPLICATION_JSON 媒体类型时,响应被额外数组包装的问题。在使用该注解时,需要注意其对数据格式和流处理方式的影响,并根据实际情况选择合适的方案。

以上就是Quarkus REST API 返回 JSON 时避免额外的数组包装的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号