jackson序列化首字母大写jackson序列化结果字段名重复

这次开发一个需求的时候, 接口传输时字段首字母要大写, jackson默认序列化时首字母会小写, 网上有人说用@JsonProperty注解标识字段名, 我试了一下确实可以让字段名大写, 但是必须在get || set方法上再加一个@JsonIgnore注解, 否则最终序列化的结果会出现重复的字段名, 一个首字母大写,一个首字母小写.  但是这种解决方案太麻烦了, 需要在每个字段和字段对应的方法上都要加注解, 我研究了一下终于发现了只需要加一行代码, 解决问题.

上代码, 我的实体类里没有写get/set方法, 而是用的@Data注解自动生成的, 在代码里写上get/set方法测试结果是一致的

实体类UserInfo

@Data
@JsonAutoDetect(fieldVisibility=JsonAutoDetect.Visibility.ANY, getterVisibility=JsonAutoDetect.Visibility.NONE)
public class UserInfo extends BaseEntity{
    
    private String Uname;

    private String sex;

    private int age;

}

关键代码就是

@JsonAutoDetect(fieldVisibility=JsonAutoDetect.Visibility.ANY, getterVisibility=JsonAutoDetect.Visibility.NONE)

Jackson默认的属性发现规则将会查找到如下所述的属性:

•所有被public修饰的字段(成员变量);

•所有被public修饰的getter(即形如“getXxx()”的方法);

•所有被public修饰的setter(即形如“setXxx(value)”的方法)

字段名是通过get方法名转换过来的, 所以会出现首字母大小写问题, 以及如果用@JsonProperty("Uname")强制序列化为某个名称时, 如果不在get/set方法上加@JsonIgnore则会出现两个uname字段,一个首字母大写, 一个首字母小写

JsonAutoDetect.Visibility.ANY : 表示所有字段都可以被发现, 包括private修饰的字段, 解决大小写问题

JsonAutoDetect.Visibility.NONE : 表示get方法不可见,解决字段重复问题

下面是测试代码

public static void main(String[] args)  throws Exception{
        UserInfo user = new UserInfo();
        user.setAge(12);
        user.setUname("name");

        ObjectMapper mapper = new ObjectMapper();
        log.info(" >>> json : {}", mapper.writeValueAsString(user));
    }

测试结果:

>>> json : {"Uname":"name","sex":null,"age":12,"topic":null}

如果不加@JsonAutoDetect(fieldVisibility=JsonAutoDetect.Visibility.ANY, getterVisibility=JsonAutoDetect.Visibility.NONE) ,

结果如下

 >>> json : {"sex":null,"age":12,"topic":null,"uname":"name"}

在Java中,可以使用Jackson库来进行自定义序列化和反序列化Jackson是一个流行的JSON处理库,提供了灵活的方式来自定义对象的序列化和反序列化行为。 要自定义Jackson序列化和反序列化,可以通过实现`JsonSerializer`和`JsonDeserializer`接口来创建自定义的序列化器和反序列化器。 下面是一个示例代码,展示了如何使用自定义的Jackson序列化和反序列化一个`Person`类: ```java import com.fasterxml.jackson.core.JsonGenerator; import com.fasterxml.jackson.core.JsonParser; import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.*; import com.fasterxml.jackson.databind.module.SimpleModule; import java.io.IOException; public class Person { private String name; private int age; // 构造函数 public Person(String name, int age) { this.name = name; this.age = age; } // 其他方法和属性... // 自定义序列化器 public static class PersonSerializer extends JsonSerializer<Person> { @Override public void serialize(Person person, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonProcessingException { jsonGenerator.writeStartObject(); jsonGenerator.writeStringField("personName", person.name); jsonGenerator.writeNumberField("personAge", person.age); jsonGenerator.writeEndObject(); } } // 自定义反序列化器 public static class PersonDeserializer extends JsonDeserializer<Person> { @Override public Person deserialize(JsonParser jsonParser, DeserializationContext deserializationContext) throws IOException, JsonProcessingException { JsonNode node = jsonParser.getCodec().readTree(jsonParser); String name = node.get("personName").asText(); int age = node.get("personAge").asInt(); return new Person(name, age); } } public static void main(String[] args) throws JsonProcessingException { ObjectMapper objectMapper = new ObjectMapper(); SimpleModule module = new SimpleModule(); module.addSerializer(Person.class, new PersonSerializer()); module.addDeserializer(Person.class, new PersonDeserializer()); objectMapper.registerModule(module); Person person = new Person("Alice", 25); String json = objectMapper.writeValueAsString(person); System.out.println(json); // 输出:{"personName":"Alice","personAge":25} Person deserializedPerson = objectMapper.readValue(json, Person.class); System.out.println(deserializedPerson.getName()); // 输出:Alice System.out.println(deserializedPerson.getAge()); // 输出:25 } } ``` 在上面的示例中,我们定义了一个`Person`类,并在类内部定义了`PersonSerializer`和`PersonDeserializer`作为自定义的序列化器和反序列化器。在`PersonSerializer`中,我们将`Person`对象的属性转换为JSON对象。在`PersonDeserializer`中,我们从JSON对象中读取属性并重新构造`Person`对象。 在`main`方法中,我们创建了一个`ObjectMapper`对象,并注册了自定义的序列化器和反序列化器。然后,我们可以使用`ObjectMapper`将`Person`对象序列化JSON字符串,并将JSON字符串反序列化为`Person`对象。 通过自定义Jackson序列化器和反序列化器,我们可以灵活地控制对象的序列化和反序列化过程,实现自定义的转换逻辑。 希望这个示例能帮助你理解如何在Java中自定义Jackson序列化和反序列化
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值