0

0

如何在 Jackson 序列化中排除未赋值(null)的 POJO 字段

心靈之曲

心靈之曲

发布时间:2026-01-10 17:35:02

|

136人浏览过

|

来源于php中文网

原创

如何在 Jackson 序列化中排除未赋值(null)的 POJO 字段

使用 jackson 时,可通过 `@jsoninclude(jsoninclude.include.non_null)` 注解全局或局部控制字段序列化行为,使值为 `null` 的字段不输出到 json 中,从而避免未显式赋值的字段以 `"fieldname": null` 形式出现。

在基于 Jackson 的 Java Web 开发中,POJO 转 JSON 时默认会将所有字段(包括未初始化或显式设为 null 的字段)一并序列化,例如:

public class A {
    private String varOne;
    private String varTwo = "assigned";
}

若仅设置 varTwo,而 varOne 保持默认 null,默认序列化结果为:

{"varOne":null,"varTwo":"assigned"}

这不仅冗余,还可能干扰前端逻辑或 API 兼容性。

推荐解决方案:使用 @JsonInclude 注解

方式一:类级别控制(推荐,简洁且可复用)
在 POJO 类上添加注解,使该类所有 null 值字段均被忽略:

import com.fasterxml.jackson.annotation.JsonInclude;

@JsonInclude(JsonInclude.Include.NON_NULL)
public class A {
    private String varOne;
    private String varTwo = "assigned";

    // getters & setters (required for Jackson)
}

此时序列化结果变为:

Short AI
Short AI

AI短视频生成器,轻松创作爆款短视频!

下载
{"varTwo":"assigned"}

✅ varOne 完全不出现,符合“未赋值即不输出”的需求。

方式二:全局配置(适用于整个应用)
在 ObjectMapper 初始化时统一设定(如 Spring Boot 中):

@Bean
public ObjectMapper objectMapper() {
    return new ObjectMapper()
        .setSerializationInclusion(JsonInclude.Include.NON_NULL);
}

⚠️ 注意事项:

  • @JsonInclude 仅对 null 值生效;若字段是基本类型(如 int、boolean),其默认值(0、false)仍会输出,需改用包装类型(Integer、Boolean)配合 NON_NULL 才能跳过。
  • 若需更精细控制(如忽略空字符串、空集合),可选用 NON_EMPTY 或自定义 JsonSerializer。
  • 该注解不影响反序列化行为——JSON 中缺失字段仍会被正确设为 null(除非配置了 @JsonSetter(nulls = Nulls.SKIP))。

? 总结:@JsonInclude(JsonInclude.Include.NON_NULL) 是最轻量、标准且符合 Jackson 最佳实践的方式,无需手动构建 JSON 或反射过滤,既安全又可维护。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

831

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

737

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

396

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

25

2026.01.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.4万人学习

C# 教程
C# 教程

共94课时 | 6.4万人学习

Java 教程
Java 教程

共578课时 | 44.6万人学习

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

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