使用BeaUtils.copyProperties时,如果源目标中包含Date类型(java.sql.date,java.util.date,java.sql.Timestamp)字段,而且该字段值为空时,会出现异常,无法赋值,解决方法是在源码中的两个类中各自增加一句代码即可:
1、ConvertUtilsBean.deregister()
public void deregister() {
converters.clear();
registerPrimitives(false);
registerStandard(false, false);
//registerOther(true);//此处为原来的代码
registerOther(false);//新增的代码
registerArrays(false, 0);
register(BigDecimal.class, new BigDecimalConverter());
register(BigInteger.class, new BigIntegerConverter());
}
2、DateTimeConverter.toDate(Class type, String value)
// java.sql.Date
//源码此处只有一个判断,及if (type.equals(java.sql.Date.class) {}
if (type.equals(java.sql.Date.class) || type.equals(java.util.Date.class)) {
try {
return java.sql.Date.valueOf(value);
} catch (IllegalArgumentException e) {
throw new ConversionException(
"String must be in JDBC format [yyyy-MM-dd] to create a java.sql.Date");
}
}
本文介绍了一种使用BeaUtils.copyProperties时遇到的问题:当复制的对象包含空日期字段时会引发异常。文章提供了具体的解决方案,通过修改源码中两处关键位置来确保日期类型的空值可以被正确处理。
485

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



