写在前面
最近在写一个小需求,中途遇到这么一个问题,总而言之,就是在java中,如何将对应的Map,转换成相应的实体类对象。
并且保证相应的参数值都能在实体类对象中赋值。
这个问题其实还是挺简单的,但是其中还是要大概分为两种情况。
其一,当实体类中所有的属性,都能在Map集合中取到的情况,当然Map中是否有其他超出实体类属性的不关心。
其二,当实体类中所有的属性,不能在Map集合中取到的情况。
解决方案
为了解决这两种情况,我们来稍作处理。
第一种的情况,其实还是非常标准的转换情况,所以通常我们会使用反射来处理这种情况,我们也提供了相应的方法,如下:
public static Object map2Bean(Map<String, Object> map, Object object) { if (map == null || object == null) { return null; } try { BeanInfo beanInfo = Introspector.getBeanInfo(object.getClass()); PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors(); for (PropertyDescriptor property : propertyDescriptors) { String key = property.getName(); if (map.containsKey(key)) { Object value = map.get(key); // 得到property对应的setter方法 Method setter = property.getWriteMethod(); setter.invoke(object, value); } } } catch (IntrospectionException | InvocationTargetException | IllegalAccessException e) { e.printStackTrace(); } return object; }
第二种的情况,稍微不太标准的情况,所以我们就不能通过反射setter方法来处理了,只能通过获取相应的属性来进行填充数据,如下:
public static Object mapToObject(Map<String, Object> map, Class<?> beanClass) throws Exception { if (map == null) { return null; } Object object = beanClass.newInstance(); Field[] fields = beanClass.getDeclaredFields(); Field[] superFields = beanClass.getSuperclass().getDeclaredFields(); convert(map, object, fields); convert(map, object, superFields); return object; } private static void convert(Map<String, Object> map, Object object, Field[] fields) throws IllegalAccessException { for (Field field : fields) { int mod = field.getModifiers(); if (Modifier.isFinal(mod) || Modifier.isStatic(mod) || ValidateUtils.isEmpty(map.get(field.getName()))) { continue; } field.setAccessible(true); field.set(object, ConvertUtils.convert(map.get(field.getName()), field.getType())); } }
这里面要说一下Field[] superFields = beanClass.getSuperclass().getDeclaredFields();
这行代码,是获取继承的父级属性,如果大家不需要可以自行删除。