Retrofit 配合 Jackson 反序列化,就是将字符串解析为java bean 对象 的时候 ,如果遇到服务端由于各种原因会导致 有些String类型的字段值为null ,需要替换为空字符串或者占位符“-”什么的,并且不确定 到底会在哪个字段,可以如下处理
这里要区分序列化和反序列化,
- 序列化,就是处理java bean对象转换为字符串,
通常设置 objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
这样在java bean中对象有值为null ,就不会将这个字段或属性序列化为字符串。
或者在java bean 模型定义中注解,表明不将其序列化@JsonInclude(JsonInclude.Include.NON_NULL)
- 反序列化,就是将服务器端返回的json串转换为java 对象,通常在处理null值, 将某些值更改为指定格式也类似。可以如下操作
在使用jackson 的时候,通常会通过 compile ‘com.squareup.retrofit2:converter-jackson:2.3.0’集成 官方的 JacksonConverterFactory ,其实它除了自动引入jackson外,另外引入了三个类,可以拷贝出来,方便修改引用,其中只需要更改 JacksonConverterFactory.java 中的create函数即可。针对反序列化过程中String类型处理,添加自定义反序列化器。
public static JacksonConverterFactory create() {
ObjectMapper objectMapper = new ObjectMapper();
SimpleModule module = new SimpleModule();
module.addDeserializer(String.class, new CustomStringDeserializer());
objectMapper.registerModule(module);
return create(objectMapper);
}
其中 CustomStringDeserializer.java 如下 ,重要的就是 getNullValue()的覆写,它决定了如果 反序列化json串中有一个字段的值是 null, 处理策略,这里是默认返回“-”。
public class CustomStringDeserializer extends JsonDeserializer<String> {
@Override
public String deserialize(JsonParser jsonparser,
DeserializationContext deserializationcontext) throws IOException,
JsonProcessingException {
return jsonparser.getText();
}
@Override
public String getNullValue() {
return "-";
}
}
这是全局处理情况,如果是类级别的,需要在类上加反序列器,但要处理的就不只是String了,类中所有字段你都需要处理,因为这时,返回的是一个类,
public class CustomClassDeserializer extends JsonDeserializer<T> {
@Override
public T deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JsonProcessingException {
return null;
}
}
然后在类的bean上使用注解,表明该类用这个反序列化器来处理
@JsonDeserialize(using = CustomClassDeserializer.class)
class yourClass()
如果是字段属性级别的
需要在相应的字段属性上这样使用
@JsonDeserialize(using = CustomStringDeserializer.class)
private String name;
还有一种情形是反序列化的时候如果字段是形如“”的空字符串,想转换成null,那就不需要覆写 getNullValue() ,直接在deserialize中处理就好。