当前位置: 首页 > news >正文

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

什么是序列化?

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

  • 序列化:将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.jsqmd.com/news/39621/

相关文章:

  • 基于多模态AI技术的传统行业智能化升级路径研究——以开源AI大模型、AI智能名片与S2B2C商城小程序为例 - 实践
  • 2025热门学宠物美容师榜:黑龙江学宠物美容师/宠物美容师培训学校毛孩精致变美秘籍!
  • react-window API完全手册:参数、方法与事件全解析 - 指南
  • 2025智慧康养/智慧养老标杆机构推荐榜:教之道五星领跑 实训室建设与虚拟仿真领域 3 家公司凭实力上榜
  • 2025氮化硼陶瓷/高温绝缘体/坩埚/套管/基板/高温构件/中子吸收材料优质厂家推荐榜:福维科五星领跑,多场景制品赋能工业升级
  • 2025健康营养饮品推荐榜:惠植健活力菌仓领衔,5 家品牌凭技术与品质,重塑火麻仁肽爆爆纤维/火麻仁肽/固体饮料与燕麦/西梅/果蔬营养素饮品新生态
  • IOS抓包------Stream
  • coze 搭建能写文案导出word pdf
  • Siemens PLCSIM V18
  • 详细介绍:Wireshark:HTTP、MQTT、WebSocket 抓包详细教程
  • 《密码系统设计》第十二周预习
  • 实用指南:数据库的事务和索引
  • 一键账户接管漏洞分析:XSS与CSRF链式攻击实战
  • C++之变量与基本类型(三) - Invinc
  • 1 移动端开发概念与环境准备
  • Vue 3 完全指南:响应式原理、组合式 API 与实战优化 - 实践
  • 创建你的第一个Java文件
  • (八大排序)快速排序(递归)
  • (八大排序)冒泡排序
  • 深入解析:手写MyBatis第111弹:Spring Boot自定义注解@MybatisMapperScan注解深度解析:从注解定义到接口代理的完整实现
  • Imbalance
  • (八大排序)堆排序
  • 2025 年 11 月展厅设计公司权威推荐榜:企业展厅、校史馆、博物馆、多媒体数字及VR线上虚拟展厅设计厂家精选
  • 点赞!开幕式背后的云力量!
  • #20232329 2025-2026-1 《网络与系统攻防技术》 实验六实验报告
  • 易路AI人才罗盘:点亮组织内部的人才“星空”,让每一次人才决策都精准有据
  • (八大排序)基数排序
  • (八大排序)希尔排序
  • 11.13 比赛总结
  • 壅土(拼音:yōng tǔ)