问题描述:今天在项目开发中遇到的问题,openfeign调用订单服务返回的时间莫名其妙多了14个小时,查看了openfeign调用服务的代码,在接收openfeign的时间类型为Date,而之前的代码,在获取openfeign的返回时间是采用字符串来接收,然后将字符串格式化,解析为日期格式。所以找到了问题的所在,openfeign调用默认返回的类型是字符串类型
问题原因:使用Date类型接收openfeign调用的返回值,会调用Date的parse()方法,而parse()方法会根据时区的偏移量进行解析,不指定时区,默认使用本地时间,CTS时区在传入时被解析为美国中部的时区,而在接收到openfeign的返回值解析时,采用的是中国时区的时间,而中国时区和美国中部时区时差正好是14个小时。废话不多说,找到问题了如何解决呢?解决方法如下:
解决方法:
1. 第一种方法: 在接收openfeign返回值类型由原来的Date类型改为String类型,在接收到返回值后,再去处理,对String类型进行格式化,解析为时间格式
2. 第二种方法: 在openfeign调用的服务端进行配置,将传入时间和返回的时间进行统一的处理
@Configuration
public class WebConfigBeans {
@Autowired
private RequestMappingHandlerAdapter handlerAdapter;
@PostConstruct
public void initEditableValidation() {
ConfigurableWebBindingInitializer initializer = (ConfigurableWebBindingInitializer) handlerAdapter
.getWebBindingInitializer();
if (initializer.getConversionService() != null) {
GenericConversionService genericConversionService = (GenericConversionService) initializer
.getConversionService();
genericConversionService.addConverter(String.class, Date.class, new String2DateConverter());
}
}
class String2DateConverter implements Converter<String, Date> {
@Override
public Date convert(String source) {
SimpleDateFormat sdf = new SimpleDateFormat(
"EEE MMM dd HH:mm:ss 'CST' yyyy", Locale.US);
try {
return sdf.parse(source);
} catch (ParseException e) {
e.printStackTrace();
}
return null;
}
}
}