1. 概述
Jackson 是 Java 生态系统中不可或缺的工具,提供了将 Java 对象序列化为 JSON 以及反序列化的功能。它的一个特性是@JsonGetter 注解,用于在序列化过程中自定义 getter 方法输出的名字。
@JsonGetter 注解概览
Jackson 的@JsonGetter 注解用来标识一个方法作为特定属性的 getter 方法。此外,还可以指定序列化 JSON 中属性的自定义名称,这可以不同于实际的 Java 属性名。
2. 开发步骤
- 创建新 Maven 项目:建立一个新的 Maven 项目。
- 引入 Jackson 依赖:添加必要的 Jackson 依赖项。
- 构建 Student 类:应用@JsonGetter 注解。
- 开发序列化类:创建一个类来处理对象到 JSON 的转换。
- 实现主方法:用于展示序列化效果。
3. 创建 Maven 项目
创建简单的 Maven 项目可以通过以下几种方式:
- 使用命令行接口
- 使用 Eclipse IDE
- 使用 IntelliJ IDEA
4. Maven 依赖项
在 pom.xml
文件中添加如下 Jackson 数据绑定依赖项:
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.13.0</version>
</dependency>
5. 代码示例
Student.java
import com.fasterxml.jackson.annotation.JsonGetter;
public class Student {
private String name;
private int age;
public Student(String name, int age) {
this.name = name;
this.age = age;
}
// 使用@JsonGetter 注解指定序列化时的属性名为 "studentName"
@JsonGetter("studentName")
public String retrieveName() {
return name;
}
// 默认的 getter 方法,不需要注解
public int getAge() {
return age;
}
}
StudentSerializer.java
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
public class StudentSerializer {
public static String serialize(Student student) throws JsonProcessingException {
ObjectMapper mapper = new ObjectMapper();
return mapper.writeValueAsString(student);
}
}
MainClass.java
public class MainClass {
public static void main(String[] args) {
Student student = new Student("John Doe", 20);
try {
String json = StudentSerializer.serialize(student);
System.out.println("序列化的 JSON: " + json);
} catch (JsonProcessingException e) {
e.printStackTrace();
}
}
}
输出结果将会是:
{"studentName":"John Doe","age":20}
代码解释
Student
类包含了一个名为 retrieveName()
的自定义 getter 方法。通过使用@JsonGetter 注解并指定 "studentName"
作为其值,序列化输出中的属性名将是 "studentName"
而不是默认从 getter 方法名派生出来的名字。StudentSerializer
类管理对象到 JSON 的转换。在 MainClass
中,我们实例化了一个学生对象并进行了序列化。最终生成的 JSON 确认了@JsonGetter 提供的自定义名称被正确使用。
6. 结论
Jackson 的@JsonGetter 注解为开发者提供了一种简单的方法来自定义序列化 JSON 中属性的命名。这种灵活性确保了输出的 JSON 可以根据特定的命名约定或需求进行定制,而不论 Java 类中的方法名称如何。这有助于提高数据交换的可读性和互操作性,特别是在需要遵循特定格式或与外部系统交互时。
标签:Jackson,JsonGetter,JSON,Student,注解,序列化,public From: https://blog.csdn.net/woshichenpi/article/details/144356503