zoukankan      html  css  js  c++  java
  • JavaBean对象与Map对象互相转化

    /** 
     * 使用org.apache.commons.beanutils进行转换 
     */  
    class A {  
          
        public static Object mapToObject(Map<String, Object> map, Class<?> beanClass) throws Exception {    
            if (map == null)  
                return null;  
      
            Object obj = beanClass.newInstance();  
      
            org.apache.commons.beanutils.BeanUtils.populate(obj, map);  
      
            return obj;  
        }    
          
        public static Map<?, ?> objectToMap(Object obj) {  
            if(obj == null)  
                return null;   
      
            return new org.apache.commons.beanutils.BeanMap(obj);  
        }    
          
    }  
      
    /** 
     * 使用Introspector进行转换 
     */  
    class B {  
      
        public static Object mapToObject(Map<String, Object> map, Class<?> beanClass) throws Exception {    
            if (map == null)   
                return null;    
      
            Object obj = beanClass.newInstance();  
      
            BeanInfo beanInfo = Introspector.getBeanInfo(obj.getClass());    
            PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();    
            for (PropertyDescriptor property : propertyDescriptors) {  
                Method setter = property.getWriteMethod();    
                if (setter != null) {  
                    setter.invoke(obj, map.get(property.getName()));   
                }  
            }  
      
            return obj;  
        }    
          
        public static Map<String, Object> objectToMap(Object obj) throws Exception {    
            if(obj == null)  
                return null;      
      
            Map<String, Object> map = new HashMap<String, Object>();   
      
            BeanInfo beanInfo = Introspector.getBeanInfo(obj.getClass());    
            PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();    
            for (PropertyDescriptor property : propertyDescriptors) {    
                String key = property.getName();    
                if (key.compareToIgnoreCase("class") == 0) {   
                    continue;  
                }  
                Method getter = property.getReadMethod();  
                Object value = getter!=null ? getter.invoke(obj) : null;  
                map.put(key, value);  
            }    
      
            return map;  
        }    
          
    }  
      
    /** 
     * 使用reflect进行转换 
     */  
    class C {  
      
        public static Object mapToObject(Map<String, Object> map, Class<?> beanClass) throws Exception {    
            if (map == null)  
                return null;    
      
            Object obj = beanClass.newInstance();  
      
            Field[] fields = obj.getClass().getDeclaredFields();   
            for (Field field : fields) {    
                int mod = field.getModifiers();    
                if(Modifier.isStatic(mod) || Modifier.isFinal(mod)){    
                    continue;    
                }    
      
                field.setAccessible(true);    
                field.set(obj, map.get(field.getName()));   
            }   
      
            return obj;    
        }    
      
        public static Map<String, Object> objectToMap(Object obj) throws Exception {    
            if(obj == null){    
                return null;    
            }   
      
            Map<String, Object> map = new HashMap<String, Object>();    
      
            Field[] declaredFields = obj.getClass().getDeclaredFields();    
            for (Field field : declaredFields) {    
                field.setAccessible(true);  
                map.put(field.getName(), field.get(obj));  
            }    
      
            return map;  
        }   
    }  

    本文转自:http://www.open-open.com/code/view/1423280939826

  • 相关阅读:
    navicat安装与激活
    MySQL 安装
    oracle中not in 和 in 的替代写法
    oracle中in和exists的区别
    oracle中nvarchar2()和varchar2()的区别
    oracle稳定执行计划(更改)的方法
    oracle显示转化字段类型
    oracle中varchar2(2)存不了一个汉字的原因
    oracle中索引快速全扫描和索引全扫描的区别
    oracle常见的执行计划
  • 原文地址:https://www.cnblogs.com/dreammyle/p/5610906.html
Copyright © 2011-2022 走看看