springboot中使用BeanUtils只拷贝对象中属性值不为null的属性
1.最近在使用JPA写一个更新数据操作的时候,流程是先根据id查询出数据,在根据前端传递的参数,使用Springboot中的BeanUtils来替换查询的数据的值,代码如下:
@Override
public Result updateDepartment(Department department) {
if(department!=null&&department.getId()!=null&&!"".equals(department.getId())){
Department dm = departmentDao.findById(department.getId()).get();
logger.error("参数"+department);
logger.error("查询"+dm);
BeanUtils.copyProperties(department,dm);
logger.error("更新"+dm);
departmentDao.save(dm);
return Result.SUCCESS();
}
return new Result(500,"id不存在",false);
}
结果发现接口一直报错,看日志才知道,原来前端更新的数据中没有createTime字段,在使用BeanUtils拷贝的时候,也把null属性值也给拷贝过去了。当然。数据库里面设置了这个字段不能为null,也就报错了。如图:
2020-08-18 18:30:38.354 ERROR 13876 --- [nio-9001-exec-1] c.l.c.s.impl.DepartmentServiceImpl : 参数Department(id=1295662819072593920, pid=1, companyId=1294188257822724096, name=管理部门, code=10005, managerId=100002, manager=guest, introduce=管理部门介绍, createTime=null)
2020-08-18 18:30:38.354 ERROR 13876 --- [nio-9001-exec-1] c.l.c.s.impl.DepartmentServiceImpl : 查询Department(id=1295662819072593920, pid=1, companyId=1294188257822724096, name=技术部门2222222, code=10005, managerId=100002, manager=admin2222, introduce=技术部门介绍2222, createTime=2020-08-18 18:04:23.0)
2020-08-18 18:30:38.356 ERROR 13876 --- [nio-9001-exec-1] c.l.c.s.impl.DepartmentServiceImpl : 更新Department(id=1295662819072593920, pid=1, companyId=1294188257822724096, name=管理部门, code=10005, managerId=100002, manager=guest, introduce=管理部门介绍, createTime=null)
解决办法,我们重写了一个工具类。来处理只拷贝属性值不为null的属性。就可以解决这个问题,代码如下:调用方式, SpringBeanUtil.copyPropertiesIgnoreNull(department,dm);
public class SpringBeanUtil implements ApplicationContextAware {
private static ApplicationContext applicationContext;
@Override
public void setApplicationContext(ApplicationContext arg0)
throws BeansException {
applicationContext = arg0;
}
public static Object getObject(String id) {
Object object = null;
object = applicationContext.getBean(id);
return object;
}
public static String[] getNullPropertyNames (Object source) {
final BeanWrapper src = new BeanWrapperImpl(source);
java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();
Set<String> emptyNames = new HashSet<String>();
for(java.beans.PropertyDescriptor pd : pds) {
Object srcValue = src.getPropertyValue(pd.getName());
if (srcValue == null) emptyNames.add(pd.getName());
}
String[] result = new String[emptyNames.size()];
return emptyNames.toArray(result);
}
public static void copyPropertiesIgnoreNull(Object src, Object target){
BeanUtils.copyProperties(src, target, getNullPropertyNames(src));
}
}
最后我们在测试一下,数据就没问题了
2020-08-18 18:35:32.337 ERROR 21536 --- [nio-9001-exec-1] c.l.c.s.impl.DepartmentServiceImpl : 参数Department(id=1295662819072593920, pid=1, companyId=1294188257822724096, name=管理部门, code=10005, managerId=100002, manager=guest, introduce=管理部门介绍, createTime=null)
2020-08-18 18:35:32.337 ERROR 21536 --- [nio-9001-exec-1] c.l.c.s.impl.DepartmentServiceImpl : 查询Department(id=1295662819072593920, pid=1, companyId=1294188257822724096, name=技术部门2222222, code=10005, managerId=100002, manager=admin2222, introduce=技术部门介绍2222, createTime=2020-08-18 18:04:23.0)
2020-08-18 18:35:32.338 ERROR 21536 --- [nio-9001-exec-1] c.l.c.s.impl.DepartmentServiceImpl : 更新Department(id=1295662819072593920, pid=1, companyId=1294188257822724096, name=管理部门, code=10005, managerId=100002, manager=guest, introduce=管理部门介绍, createTime=2020-08-18 18:04:23.0)