产生原因:OpenFeign跨服务调用查询相关信息, 在返回List时发现出现序列化异常。
feign.codec.DecodeException: Error while extracting response for type [com.ev.amp.common.R<java.util.List<com.ev.amp.plant.dto.AlgoDTO$AlgoInfo>>] and content type [application/json]; nested exception is org.springframework.http.converter.HttpMessageNotReadableException:
JSON parse error: Cannot deserialize instance of `java.util.ArrayList<java.lang.Object>` out of VALUE_STRING token; nested exception is com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `java.util.ArrayList<java.lang.Object>` out of VALUE_STRING token
at [Source: (PushbackInputStream); line: 1, column: 187] (through reference chain: com.ev.amp.common.R["data"]->java.util.ArrayList[0]->com.ev.amp.plant.dto.AlgoDTO$AlgoInfo["analysisRequires"])
at feign.AsyncResponseHandler.decode(AsyncResponseHandler.java:119)
**分析:**看到序列化失败,首先需要清楚数据返回结果以及接收参数DTO是怎样的!
通过swagger调用,返回结果如下

再来看看接收类

实体类分明定义的是list,却序列化成"",导致后续Feign Decode解码器序列化失败了。由此可知,是JSON序列化出现问题了。
解决方法:
- 即是序列化出现问题,需要弄清返回请求结果时使用的序列化方式。java常用的序列化方式:FastJson和Jackson(gson不常用)。而我们使用的是Jackson。

2.找到Jackson配置
public ObjectMapper jacksonObjectMapper() {
ObjectMapper objectMapper = JacksonUtils.getInstance();
/* 省略 */
objectMapper.configure(DeserializationFeature.ACCEPT_EMPTY_STRING_AS_NULL_OBJECT, true);
return objectMapper;
}
3.利用反射获取属性类型,分情况进行赋值
objectMapper.getSerializerProvider().setNullValueSerializer(new JsonSerializer<Object>() {
@Override
public void serialize(Object o, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException {
String fieldName = jsonGenerator.getOutputContext().getCurrentName();
//反射获取字段类型
Field field = ReflectUtil.getField(jsonGenerator.getCurrentValue().getClass(), fieldName);
if (Objects.equals(field.getType(), List.class)) {
//列表型空值返回[]
jsonGenerator.writeStartArray();
jsonGenerator.writeEndArray();
} else {
// 字段保留,将null值转为""
jsonGenerator.writeString("");
}
}
});

文章讲述了在使用OpenFeign进行跨服务调用时遇到的序列化异常,分析了原因在于Jackson配置导致空List被序列化为STRING,给出了通过反射调整null值序列化的解决方案。
5203

被折叠的 条评论
为什么被折叠?



