Spring:jackson-annotaions注解大全

文章目录

一、介绍

jackson-annotations 是 Jackson 库的一部分,它提供了一系列注解,用于控制 Java 对象与 JSON 之间的序列化和反序列化过程。

二、@JsonProperty

用于指定 Java 类的属性名与 JSON 中的字段名之间的映射关系。

复制代码
public class User {  
    @JsonProperty("user_name")  
    private String name;  

    // getters and setters  
}

在上面的例子中,Java 对象的 name 属性将被序列化为 JSON 字段 user_name。

三、@JsonIgnore

用于指定某个 Java 类的属性在序列化为 JSON 时被忽略。

复制代码
public class User {  
    private String name;  

    @JsonIgnore  
    private String password;  

    // getters and setters  
}

在上面的例子中,password 属性在序列化为 JSON 时将被忽略。

四、@JsonInclude

用于指定在序列化时哪些值应该被包含。例如,可以使用 @JsonInclude(Include.NON_NULL) 来只包含非空值。

复制代码
@JsonInclude(Include.NON_NULL)  
public class User {  
    private String name;  
    private String email;  

    // getters and setters  
}

在上面的例子中,如果 email 为 null,则不会被包含在序列化的 JSON 中。

五、@JsonFormat

用于自定义日期和时间的格式。

复制代码
public class Event {  
    @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss")  
    private Date eventDate;  

    // getters and setters  
}

在上面的例子中,eventDate 属性将按照指定的日期时间格式进行序列化和反序列化。

六、@JsonCreator 和 @JsonProperty (在构造函数中)

用于自定义反序列化时的构造函数。

复制代码
public class User {  
    private String name;  
    private int age;  

    @JsonCreator  
    public User(@JsonProperty("user_name") String name, @JsonProperty("user_age") int age) {  
        this.name = name;  
        this.age = age;  
    }  

    // getters and setters  
}

在上面的例子中,我们使用了一个带有 @JsonCreator 注解的构造函数,并使用 @JsonProperty 注解来指定 JSON 字段与 Java 构造函数参数之间的映射关系。

七、@JsonTypeName 和 @JsonTypeInfo

用于处理多态类型。

复制代码
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "type")  
@JsonTypeName("employee")  
public class Employee {  
    // ...  
}  

public class Manager extends Employee {  
    // ...  
}

在上面的例子中,Employee 和 Manager 类都可以被序列化为 JSON,并且包含一个 type 字段来指示对象的实际类型。反序列化时,可以根据这个 type 字段来创建正确的对象实例。

八、@JsonIgnoreProperties

  • 作用:在序列化或反序列化时忽略Java Bean中的某些属性。
  • 示例:@JsonIgnoreProperties({"propertyName1", "propertyName2"})
  • 注意:这是一个类注解,可以指定多个要忽略的属性名。

九、@JsonSerialize

  • 作用:用于自定义属性的序列化方式。
  • 示例:配合自定义的序列化器使用,如@JsonSerialize(using = CustomSerializer.class)
  • 注意:可以作用于属性或getter方法上。

十、@JsonDeserialize

  • 作用:用于自定义属性的反序列化方式。
  • 示例:配合自定义的反序列化器使用,如@JsonDeserialize(using = CustomDeserializer.class)
  • 注意:可以作用于属性或setter方法上。
相关推荐
小马爱打代码13 分钟前
Spring框架:介绍和快速入门
java·后端·spring
霸道流氓气质1 小时前
Spring AI Alibaba + Ollama Function Calling 项目完整指南
人工智能·windows·spring
星轨zb2 小时前
从通用到专属:文迹(WenJi)引入 RAG 向量库的技术复盘
java·spring·langchain4j
架构源启2 小时前
Spring AI进阶系列(14)- 2026 可观测性最佳实践:从链路追踪到企业级 AI 治理落地
java·人工智能·spring
椰椰椰耶3 小时前
[SpringCloud][12]Nacos配置中心详解,快速上手,Nacos和Eureka的区别
spring·spring cloud·eureka
来杯@Java12 小时前
图书管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·mybatis·课程设计
卷毛的技术笔记13 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
云烟成雨TD17 小时前
Spring AI 1.x 系列【33】RAG Advisor 组件与四大分层架构
java·人工智能·spring
J2虾虾18 小时前
Spring AI Alibaba - Tools
服务器·人工智能·spring
J2虾虾20 小时前
Spring AI Alibaba - 人工介入(Human-in-the-Loop)
java·人工智能·spring