0

0

如何使用 Jackson 动态为泛型包装类生成带类型名称的 JSON 结构

花韻仙語

花韻仙語

发布时间:2026-01-27 09:40:01

|

200人浏览过

|

来源于php中文网

原创

如何使用 Jackson 动态为泛型包装类生成带类型名称的 JSON 结构

本文介绍如何通过 jackson 的 `@jsontypeinfo` 与 `@jsontypename` 注解,结合泛型 wrapper 类,实现将不同子类型(如 payloadfoo、payloadbar)序列化为以类型名(如 `"foo"`、`"bar"`)为字段名的顶层 json 对象。

Jackson 原生不支持直接将泛型类型参数(如 Wrapper)自动映射为以类名小写为键的 JSON 字段(如 "foo": { ... }),但可通过 多态序列化机制 巧妙达成目标:将 Wrapper 设计为抽象基类或启用类型信息注入,并借助 @JsonTypeInfo 指定“属性式”类型标识(use = JsonTypeInfo.Id.NAME)和包含位置(include = JsonTypeInfo.As.WRAPPER_OBJECT),使 Jackson 在序列化时自动将整个对象包裹在以子类型名称为键的外层对象中。

关键实现步骤如下:

  1. 为 Wrapper 类添加多态元数据
    使用 @JsonTypeInfo 启用类型识别,并设置 include = JsonTypeInfo.As.WRAPPER_OBJECT —— 这是实现 "foo": { ... } 结构的核心。同时配合 @JsonSubTypes 显式注册所有可能的子类型及其对应名称:

    @JsonTypeInfo(
        use = JsonTypeInfo.Id.NAME,
        include = JsonTypeInfo.As.WRAPPER_OBJECT, // ✅ 关键:生成外层命名包装对象
        property = "" // 空字符串表示不额外添加类型字段,仅用键名体现类型
    )
    @JsonSubTypes({
        @JsonSubTypes.Type(value = PayloadFoo.class, name = "foo"),
        @JsonSubTypes.Type(value = PayloadBar.class, name = "bar")
    })
    @Data
    @NoArgsConstructor
    @AllArgsConstructor
    public static class Wrapper {
        private SoaHeader soaHeader;
        private T payload;
    }
  2. 为具体载荷类标注 @JsonTypeName
    PayloadFoo 和 PayloadBar 需分别标注 @JsonTypeName("foo") 和 @JsonTypeName("bar"),确保 Jackson 能正确关联类型名与实现类:

    @JsonTypeName("foo")
    @Data
    public static class PayloadFoo {
        private String foo;
    }
    
    @JsonTypeName("bar")
    @Data
    public static class PayloadBar {
        private String bar;
    }
  3. 注意泛型擦除限制与最佳实践

    Creatie
    Creatie

    Creatie AI是一款专为UI/UX设计师打造的AI增强设计工具,致力于通过AI优化设计流程

    下载
    • Jackson 在运行时无法获取泛型 T 的真实类型(类型擦除),因此 Wrapper 必须作为多态基类参与序列化,不能仅靠泛型推断;必须显式注册所有子类型。
    • @JsonTypeInfo.As.WRAPPER_OBJECT 要求被序列化的对象必须是 @JsonSubTypes 中声明的具体子类实例(如 new Wrapper(...)),且需确保 payload 字段值非 null,否则可能触发空 Bean 异常(建议配置 configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false))。
    • 若需更高灵活性(如动态注册类型),可考虑自定义 Serializer 或使用 ObjectWriter.withType() 显式指定类型,但会牺牲简洁性。

最终,调用 ObjectMapper 序列化时即可获得预期结构:

Wrapper fooWrapper = new Wrapper<>(new SoaHeader(), new PayloadFoo("test"));
String json = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(fooWrapper);
// 输出:
// {
//   "foo": {
//     "soaHeader": {},
//     "payload": {
//       "foo": "test"
//     }
//   }
// }

✅ 总结:该方案无需反射或手动构造 Map,完全基于 Jackson 标准注解,语义清晰、可维护性强,适用于 SOA 场景中统一响应包装器(如含 header + typed payload)的标准化 JSON 输出。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

418

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

235

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

437

2024.03.01

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.11.27

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.11.27

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

6

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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