Feign接口日期格式转换的一个小问题
--洱涷zZ
背景:
最近在写api
调用H0
平台提供接口的时候,发现消费端Feign接口在路由、格式等条件都没问题的情况下,服务端返回的数据无法正常接收到,而是一直报错:
feign.codec.DecodeException: JSON parse error: Can not deserialize value of type java.util.Date from String "2021-10-25 16:18:35": not a valid representation (error: Failed to parse Date value '2021-10-25 16:18:35': Can not parse date "2021-10-25 16:18:35Z": while it seems to fit format 'yyyy-MM-dd'T'HH:mm:ss.SSS'Z'', parsing fails (leniency? null));
我们可以看到是其返回的JSON
字符串中有Date类型的字段转换失败,为什么会出现这种情况呢?
探究:
从异常信息中我们可以看出,是在AbstractJackson2HttpMessageConverter
类中调用了readJavaType
方法之后抛的异常,
一步一步往下深入,我们找到了最关键的地方,在DeserializationContext
类的parseDate
方法中,执行了df.parse(dateStr)
之后抛异常了
public Date parseDate(String dateStr) throws IllegalArgumentException{
try {
DateFormat df = getDateFormat(); // 这行代码报错了
return df.parse(dateStr);
} catch (ParseException e) {
throw new IllegalArgumentException(String.format(
"Failed to parse Date value '%s': %s", dateStr, e.getMessage()));
}
}
DeserializationContext
是jackson
的一个反序列化的一个上下文,那么它的DateFormat
是从哪来的呢?我们再来看下getDateFormat
的源码:
protected DateFormat getDateFormat() {