如果我们拿到了一串 JSON 字符串,需要用实体类进行反序列化,但是 JSON 字符串中的 key 和实体类的属性名不一致,这时就需要解决 JSON 串和实体类字段不一致的问题。
解决这个问题的方法有以下三种:
Json 序列化和反序列化框架 Jackson 提供了注解 @JsonProperty,可以用来将实体类的属性和 JSON 串的 key 进行对应。
示例:
JSON 串:
{
"name": "小明",
"age": 18
}
实体类:
public class Person {
@JsonProperty("name")
private String personName;
private int age;
// 省略 getter 和 setter 方法
}
通过 @JsonProperty("name") 注解实体类的属性 personName,可以与 JSON 串中的 name key 进行对应,从而解决字段不一致的问题。
如果实体类中的属性名和 JSON 串中的 key 更加复杂,无法通过简单的注解来解决,就可以通过实现自定义反序列化器来进行解决。
示例:
JSON 串:
{
"user-name": "小明",
"user_age": 18
}
实体类:
public class User {
private String userName;
private int userAge;
// 省略 getter 和 setter 方法
}
自定义反序列化器:
public class UserDeserializer extends JsonDeserializer<User> {
@Override
public User deserialize(JsonParser p, DeserializationContext ctxt)
throws IOException, JsonProcessingException {
JsonNode node = p.getCodec().readTree(p);
String name = node.get("user-name").asText();
int age = node.get("user_age").asInt();
return new User(name, age);
}
}
这里我们自定义了一个 UserDeserializer 类,继承了 Jackson 提供的 JsonDeserializer 类,并重写了其中的 deserialize 方法,通过 JsonNode 获取 JSON 串中的数据,进行自定义转换。
然后在实体类中使用 @JsonDeserialize 注解,指定使用刚才定义的反序列化器即可。
@JsonDeserialize(using = UserDeserializer.class)
public class User {
private String userName;
private int userAge;
// 省略 getter 和 setter 方法
}
以上是解决 JSON 串和实体类字段不一致的两种方法,根据业务需要选择适合自己的方法即可。