序列化概念及Jackson注解实现动态JSON响应

news/2025/11/13 19:39:11/文章来源:https://www.cnblogs.com/ztn195/p/19218990

什么是序列化?

序列化就像把一本书翻译成其他语言的过程:

  • 序列化:将Java对象转换为JSON字符串(就像把中文书翻译成英文)

  • 反序列化:将JSON字符串转换回Java对象(就像把英文书翻译回中文)

在我们的API开发中,序列化让Java对象能够通过网络传输,被其他系统理解。

基础序列化示例

先来看一个简单的例子:

public class User {private String name;private Integer age;private String email;// 构造方法、getter、setter...
}User user = new User("张三", 25, "zhangsan@example.com");

默认序列化结果:

{"name": "张三","age": 25,"email": "zhangsan@example.com"
}

问题场景:我们的工具检测API

现在有一个响应DTO类

public class ToolDetectionResponse {
    private boolean success;
    private String msg;
    private int total;
    private List<ToolItem> tools;
    private String archive_id;
    private String image_url;
    
    // getter、setter...
}

由于接口文档已经写好了,我们需要处理两种不同的响应情况:

需求分析

  1. 成功时:返回完整的检测结果

  2. 失败时:只返回错误信息,不包含数据字段

// 理想中的成功响应
{"success": true,"total": 5,"tools": [...],"archive_id": "...","image_url": "..."
}// 理想中的失败响应  
{"success": false,"msg": "错误描述"
}

 但是目前失败响应的格式是:

{"success": false,"msg": "错误描述","total": 0,           // 不想要的字段!"tools": null,        // 不想要的字段!"archive_id": null,   // 不想要的字段!"image_url": null     // 不想要的字段!
}

引入 @JsonInclude

@JsonInclude(JsonInclude.Include.NON_NULL)
public class ToolDetectionResponse {private boolean success;private String msg;private int total;private List<ToolItem> tools;private String archive_id;private String image_url;
}

@JsonInclude注解用于控制当字段值为空时是否参与序列化。

@JsonInclude(JsonInclude.Include.NON_NULL)
public class ToolDetectionResponse {// 类级别的注解:所有为null的字段都不会被序列化
}

常用参数:

  • NON_NULL:值为null时不序列化

  • NON_EMPTY:值为null或空时不序列化

  • NON_DEFAULT:值为默认值时不序列化

现在失败响应变成了:

{"success": false,"msg": "只支持图片文件","total": 0    // 还是有问题!int类型不能为null,总是会显示0
}

核心问题:基本类型 vs 包装类型

  • int total:基本类型,默认值0,不能为null

  • Integer total:包装类型,可以为null

由于接口文档已经写好了,要求不能修改字段类型!

引入@JsonIgnore

//这是我们最终采用的方案,结合了多个注解:
@JsonInclude(JsonInclude.Include.NON_NULL)
public class ToolDetectionResponse {@JsonProperty("success")private boolean success;@JsonProperty("msg")private String msg;// 核心技巧:使用@JsonIgnore隐藏基础字段@JsonIgnoreprivate int total;@JsonProperty("tools")private List<ToolItem> tools;@JsonProperty("archive_id")private String archive_id;@JsonProperty("image_url")private String image_url;/*** 自定义序列化逻辑:只有成功时才序列化total字段*/@JsonProperty("total")public Integer getTotalForJson() {return this.success ? this.total : null;}
}

@JsonIgnore用于完全忽略字段的序列化和反序列化。

@JsonIgnore
private int total; // 这个字段不会被序列化

但这样会完全忽略字段,我们需要的是有条件的序列化。

为了实现"成功时序列化,失败时不序列化"的需求,我们采用组合方案:

@JsonIgnore
private int total; // 基础字段被忽略@JsonProperty("total")
public Integer getTotalForJson() {return this.success ? this.total : null;
}

工作原理:

  1. @JsonIgnore让基础字段total不被序列化

  2. 自定义方法getTotalForJson()使用@JsonProperty("total")声明要序列化的字段

  3. 方法内根据success字段决定返回值:

    • 成功:返回实际的total值

    • 失败:返回null,由于类上有@JsonInclude(NON_NULL),所以不会被序列化

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/964662.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于多模态AI技术的传统行业智能化升级路径研究——以开源AI大模型、AI智能名片与S2B2C商城小程序为例 - 实践

基于多模态AI技术的传统行业智能化升级路径研究——以开源AI大模型、AI智能名片与S2B2C商城小程序为例 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; displ…

2025热门学宠物美容师榜:黑龙江学宠物美容师/宠物美容师培训学校毛孩精致变美秘籍!

随着宠物行业的蓬勃发展,宠物美容师成为备受追捧的职业,优质的培训学校是零基础从业者入行的关键。本次 2025 宠物美容师培训推荐榜,聚焦行业正规机构,从办学资质、教学实力、就业保障等核心维度筛选,为意向学习者…

react-window API完全手册:参数、方法与事件全解析 - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

2025智慧康养/智慧养老标杆机构推荐榜:教之道五星领跑 实训室建设与虚拟仿真领域 3 家公司凭实力上榜

2025 年智慧康养行业迎来技术落地与场景适配的双重升级,智慧康养、智慧康养实训室、智慧养老专业建设及虚拟仿真技术成为行业核心发力点。综合技术实用性、场景覆盖度与用户反馈,推出优质企业推荐榜,为行业选择提供…

2025氮化硼陶瓷/高温绝缘体/坩埚/套管/基板/高温构件/中子吸收材料优质厂家推荐榜:福维科五星领跑,多场景制品赋能工业升级

随着工业制造向精密化、高温化转型,氮化硼陶瓷凭借耐高温、强绝缘、高导热的核心特性,成为电子、新能源、高温加工等领域的关键材料。2025 年榜单聚焦产品实力与场景适配性,精选 4 家优质企业,为行业选择提供参考。…

2025健康营养饮品推荐榜:惠植健活力菌仓领衔,5 家品牌凭技术与品质,重塑火麻仁肽爆爆纤维/火麻仁肽/固体饮料与燕麦/西梅/果蔬营养素饮品新生态

2025 年健康消费市场持续升级,营养素饮品与固体饮料凭借便捷性、功能性成为大众日常选择。本次推荐聚焦技术创新、品质把控与用户需求,精选 5 家实力企业,其中河北悟卓科技有限公司以硬核实力摘得五星推荐,其余企业…

IOS抓包------Stream

安装和配置见下方教程 https://blog.csdn.net/weixin_44504146/article/details/121946958

coze 搭建能写文案导出word pdf

coze 搭建能写文案导出word pdf

Siemens PLCSIM V18

Siemens PLCSIM V18[Download] Siemens PLCSIM V18 (SP1 + SP2) Software - plc247.com

详细介绍:Wireshark:HTTP、MQTT、WebSocket 抓包详细教程

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

《密码系统设计》第十二周预习

20231313 张景云《密码系统设计》第十二周预习AI对内容的总结Headfirst C 一、线程核心概念与基础操作 1. 线程本质线程是进程内的“轻量级执行单元”,同一进程的多个线程共享堆内存、文件描述符、套接字等资源,可并…

实用指南:数据库的事务和索引

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

一键账户接管漏洞分析:XSS与CSRF链式攻击实战

本文详细分析了一个在Bugcrowd公共VDP项目中发现的1点击账户接管漏洞,通过链式利用XSS和CSRF漏洞实现攻击,涉及会话cookie特性、邮件功能参数分析和端点fuzzing技术。在Bugcrowd公共项目中发现的一键账户接管漏洞 ب…

ai agent 智能体 prompt ragflow langflow n8n dify

ai agent 智能体 prompt ragflow langflow n8n dify# 角色你是瑞老师,一位经验丰富且专业的教育工作者,擅长根据用户提供的课题,编写符合新课标的教案。 ## 技能### 技能 1: 编写教案1. 当用户提供课题后,深入分析…

1 移动端开发概念与环境准备

1 移动端开发概念与环境准备1.1 移动端开发相关概念 1.1.1 APP类型(1)Native APP Native APP又称原生APP,就是我们平时说的手机/桌面应用软件。 原生APP 是针对IOS、Android、Windows、鸿蒙等不同的手机操作系统要采…

C++之变量与基本类型(三) - Invinc

本文记录了C++中与变量与基本类型相关的容易遗忘的一些知识。本文记录了C++中与变量与基本类型相关的容易遗忘的一些知识。变量基本类型 整数类型 short, int, long, long long C++标准规定:short 至少 16 位; int至…

Vue 3 完全指南:响应式原理、组合式 API 与实战优化 - 实践

Vue 3 完全指南:响应式原理、组合式 API 与实战优化 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Conso…

创建你的第一个Java文件

1.新建一个code文件夹,存放代码 2.新建一个Java文件 1.新建一个code文件夹,存放代码 2.新建一个Java文件Hello.java注意后缀public class Hello{public static void main(String[] args){System.out.print("Hel…