先看序列化操作(JsonIgnoreSerialization.java),如下所示,Test类的field1字段和getField2方法都有JsonIgnore注解:
static class Test { private String field0; @JsonIgnore private String field1; private String field2; public String getField0() { return field0; } public void setField0(String field0) { this.field0 = field0; } public String getField1() { return field1; } public void setField1(String field1) { this.field1 = field1; } public void setField2(String field2) { this.field2 = field2; } @JsonIgnore public String getField2() { return field2; } }给field0、field1、field2三个字段都赋值,再看序列化结果,如下图,可见field0和field2都被忽略了:
再来尝试JsonIgnore注解在反序列化场景的作用,注意反序列化的时候,JsonIgnore作用的方法应该是set了,如下图:
另外实测发现,反序列化的时候,JsonIgnore注解在get方法上也可以让对应字段被忽略;
JacksonInjectJacksonInject的作用是在反序列化的时候,将配置好的值注入被JacksonInject注解的字段;
如下所示,Test类的field1和field2都有JacksonInject注解,不同的是field1指定了注入值的key为defaultField1,而field2由于没有指定key,只能按照类型注入:
static class Test { private String field0; @JacksonInject(value = "defaultField1") private String field1; @JacksonInject private String field2;注入时所需的数据来自哪里呢?如下所示,通过代码配置的,可以指定key对应的注入值,也可以指定类型对应的注入值:
InjectableValues.Std injectableValues = new InjectableValues.Std(); // 指定key为"defaultField1"对应的注入参数 injectableValues.addValue("defaultField1","field1 default value"); // 指定String类型对应的注入参数 injectableValues.addValue(String.class,"String type default value"); ObjectMapper mapper = new ObjectMapper(); // 把注入参数的配置设置给mapper mapper.setInjectableValues(injectableValues);反序列化结果如下图,可见field1和field2的值都是被注入的:
JsonSerializeJsonSerialize用于序列化场景,被此注解修饰的字段或者get方法会被用于序列化,并且using属性指定了执行序列化操作的类;
执行序列化操作的类,需要继承自JsonSerializer,如下所示,Date2LongSerialize的作用是将Date类型转成long类型:
static class Date2LongSerialize extends JsonSerializer<Date> { @Override public void serialize(Date value, JsonGenerator gen, SerializerProvider serializers) throws IOException { gen.writeNumber(value.getTime()); } }Test类的field0字段是私有的,且没有get和set方法,但是添加了注释JsonDeserialize就能被反序列化了,并且使用Date2LongSerialize类对将json中的long型转成field0所需的Date型:
static class Test { @JsonDeserialize(using = Long2DateDeserialize.class) private Date field0; @Override public String toString() { return "Test{" + "field0='" + field0 + '\'' + '}'; } }执行结果如下:
JsonDeserializeJsonDeserialize用于反序列化场景,被此注解修饰的字段或者set方法会被用于反序列化,并且using属性指定了执行反序列化操作的类;
执行反序列化操作的类需要继承自JsonDeserializer,如下所示,Long2DateDeserialize的作用是将Long类型转成field0字段对应的Date类型:
static class Long2DateDeserialize extends JsonDeserializer<Date> { @Override public Date deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JsonProcessingException { if(null!=p && null!=ctxt && p.getLongValue()>0L ) { return new Date(p.getLongValue()); } return null; } }测试反序列化,结果如下:
JsonRawValue最后要介绍的是JsonRawValue,使用该注解的字段或者方法,都会被序列化,但是序列化结果是原始值,例如字符串是不带双引号的: