首页 > Java > java教程 > 正文

Quarkus REST API 返回 JSON 时去除额外的数组包装

碧海醫心
发布: 2025-07-12 16:04:11
原创
890人浏览过

quarkus rest api 返回 json 时去除额外的数组包装

正如摘要中所述,本文将探讨如何在使用 Quarkus 构建 REST API 时,避免返回 JSON 数据时出现额外的数组包装。当使用 Multi<String> 作为返回类型,并指定 MediaType.APPLICATION_JSON 时,Quarkus 默认会将所有结果收集到一个列表中,然后将该列表作为 JSON 数组返回。这可能不是我们期望的行为,特别是当我们需要返回一个单独的 JSON 对象时。

问题描述

在 Quarkus REST API 中,如果使用 Multi 来返回 JSON 数据,可能会遇到响应被额外的数组包装的情况。例如,以下代码:

  @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 文件的内容如下:

{
  "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) 注解。此注解指示 Resteasy 直接将每个值写入响应,而无需进行任何格式化。

Find JSON Path Online
Find JSON Path Online

Easily find JSON paths within JSON objects using our intuitive Json Path Finder

Find JSON Path Online30
查看详情 Find JSON Path Online
  @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) 注解,Resteasy 将不会收集所有值并将它们包装到列表中。而是将每个字符串直接写入响应流,从而避免了额外的数组包装。

原理解析

根据 Resteasy 的文档,如果没有 @Stream 注解,Resteasy 会收集 Multi 中的所有值,然后将它们包装到一个 java.util.List 实体中,并将其发送到客户端。而使用 @Stream(Stream.MODE.RAW) 注解后,每个值都会在可用时直接写入网络,无需任何格式化。

注意事项

使用 @Stream(Stream.MODE.RAW) 注解不仅会改变响应的格式,还会影响 "reactivity",即是否等待整个 Multi 完成生成值后再批量发送,还是逐个发送。这可能是一个重要的考虑因素,具体取决于应用程序的需求。

如果需要返回一个单独的 JSON 对象,并且不需要流式处理的特性,那么最好避免使用 Multi<String> 作为返回类型。可以考虑直接返回一个 JSON 对象,例如使用 javax.json.JsonObject 或者自定义的 Java Bean。

总结

通过使用 @Stream(Stream.MODE.RAW) 注解,可以有效避免在使用 Quarkus 构建 REST API 时,Multi<String> 返回类型导致的额外数组包装问题。这种方法提供了更灵活的流式响应处理,但也需要根据实际需求仔细考虑其影响。在选择返回类型时,应权衡流式处理的优势与直接返回 JSON 对象的简洁性。

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

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

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

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

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