commons-beanutils
是Apache开源组织提供的用于操作JAVA BEAN的工具包。使用commons-beanutils
,我们可以很方便的对bean对象的属性进行操作。今天为大家介绍一下该包的常用方法。
在介绍常用类之前,我们先来 编写一个用于测试的BEAN类:
package com.gujin.entity;public class UserInfo { private String userId; private String userName; public UserInfo() { } public UserInfo(String userId, String userName) { this.userId = userId; this.userName = userName; } public String getUserId() { return userId; } public void setUserId(String userId) { this.userId = userId; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } @Override public String toString() { return String.format("{userId:%s,userName:%s}", userId, userName); } }
MethodUtils
MethodUtils
通过反射访问对象的方法并且执行方法。
方法摘要:
返回值 | 方法名 | 说明 |
---|---|---|
static int | clearCache() | 清空方法缓存 |
static Method | getAccessibleMethod(Class<?> clazz, Method method) | 返回一个可访问的方法 |
static Method | getAccessibleMethod(Class<?> clazz, String methodName, Class<?> parameterType) | 返回一个可访问的方法 |
static Method | getAccessibleMethod(Class<?> clazz, String methodName, Class<?>[] parameterTypes) | 返回一个可访问的方法 |
static Method | getAccessibleMethod(Method method) | 返回一个可访问的方法 |
static Method | getMatchingAccessibleMethod(Class<?> clazz, String methodName, Class<?>[] parameterTypes) | 查找与方法名及参数匹配的可访问方法 |
static Class<?> | getPrimitiveType(Class<?> wrapperType) | 获得包装类的基本数据类型 |
static Class<?> | getPrimitiveWrapper(Class<?> primitiveType) | 获得基本数据类型的包装类型 |
static Object | invokeExactMethod(Object object, String methodName, Object arg) | 执行方法 |
static Object | invokeExactMethod(Object object, String methodName, Object[] args) | 执行方法 |
static Object | invokeExactMethod(Object object, String methodName, Object[] args, Class<?>[] parameterTypes) | 执行方法 |
static Object | invokeExactStaticMethod(Class<?> objectClass, String methodName, Object arg) | 执行静态方法 |
static Object | invokeExactStaticMethod(Class<?> objectClass, String methodName, Object[] args) | 执行静态方法 |
static Object | invokeExactStaticMethod(Class<?> objectClass, String methodName, Object[] args, Class<?>[] parameterTypes) | 执行静态方法 |
static Object | invokeMethod(Object object, String methodName, Object arg) | 执行方法 |
static Object | invokeMethod(Object object, String methodName, Object[] args) | 执行方法 |
static Object | invokeMethod(Object object, String methodName, Object[] args, Class<?>[] parameterTypes) | 执行方法 |
static Object | invokeStaticMethod(Class<?> objectClass, String methodName, Object arg) | 执行静态方法 |
static Object | invokeStaticMethod(Class<?> objectClass, String methodName, Object[] args) | 执行静态方法 |
static Object | invokeStaticMethod(Class<?> objectClass, String methodName, Object[] args, Class<?>[] parameterTypes) | 执行静态方法 |
static boolean | isAssignmentCompatible(Class<?> parameterType, Class<?> parameterization) | 确定是否可以使用一个类型作为方法调用参数 |
static void | setCacheMethods(boolean cacheMethods) | 设置缓存方法 |
static Class<?> | toNonPrimitiveClass(Class<?> clazz) | 如果是简单数据类型则返回对应的包装类,否则返回本身 |
使用示例:
package com.gujin.beanutils;import java.lang.reflect.Method;import org.apache.commons.beanutils.MethodUtils;import org.junit.Test;import com.gujin.entity.UserInfo; public class MethodUtilsTest { @Test public void test() throws Exception { UserInfo userInfo = new UserInfo(); // 通过方法名和参数类型获得可访问方法 Method method = MethodUtils.getAccessibleMethod(UserInfo.class, "setUserId", String.class); method.invoke(userInfo, "jianggujin"); // 可以直接通过invokeMethod执行方法 MethodUtils.invokeMethod(userInfo, "setUserName", "蒋固金"); System.out.println(userInfo); } }
运行结果:
{userId:jianggujin,userName:蒋固金}
ConstructorUtils
ConstructorUtils
通过反射提供了构造方法相关的便捷操作方法。
方法摘要:
返回值 | 方法名 | 说明 |
---|---|---|
static <T> Constructor<T> | getAccessibleConstructor(Class<T> klass, Class<?> parameterType) | 获得含有一个形参的构造方法 |
static <T> Constructor<T> | getAccessibleConstructor(Class<T> klass, Class<?>[] parameterTypes) | 获得含有指定类型形参的构造方法 |
static <T> Constructor<T> | getAccessibleConstructor(Constructor<T> ctor) | 获得可访问构造方法 |
static <T> T | invokeConstructor(Class<T> klass, Object arg) | 执行构造方法 |
static <T> T | invokeConstructor(Class<T> klass, Object[] args) | 执行构造方法 |
static <T> T | invokeConstructor(Class<T> klass, Object[] args, Class<?>[] parameterTypes) | 执行构造方法 |
static <T> T | invokeExactConstructor(Class<T> klass, Object arg) | 执行构造方法 |
static <T> T | invokeExactConstructor(Class<T> klass, Object[] args) | 执行构造方法 |
static <T> T | invokeExactConstructor(Class<T> klass, Object[] args, Class<?>[] parameterTypes) | 执行构造方法 |
使用示例:
package com.gujin.beanutils;import java.lang.reflect.Constructor;import org.apache.commons.beanutils.ConstructorUtils;import org.junit.Test;import com.gujin.entity.UserInfo; public class ConstructorUtilsTest { @Test public void test() throws Exception { Constructorconstructor = ConstructorUtils .getAccessibleConstructor(UserInfo.class, new Class[] { String.class, String.class }); System.out.println(constructor.newInstance("jianggujin", "蒋固金")); // 更简洁的写法 UserInfo userInfo = ConstructorUtils.invokeConstructor(UserInfo.class, new String[] { "jianggujin", "蒋固金" }); System.out.println(userInfo); } }
运行结果:
{userId:jianggujin,userName:蒋固金} {userId:jianggujin,userName:蒋固金}
PropertyUtils
PropertyUtils
通过反射提供了对象属性的便捷操作方法。
方法摘要:
返回值 | 方法名 | 说明 |
---|---|---|
static void | addBeanIntrospector(BeanIntrospector introspector) | 添加一个BeanIntrospector |
static void | clearDescriptors() | 清空所有属性描述信息 |
static void | copyProperties(Object dest, Object orig) | 复制属性 |
static Map<String,Object> | describe(Object bean) | 属性描述 |
static Object | getIndexedProperty(Object bean, String name) | 指定索引属性值 |
static Object | getIndexedProperty(Object bean, String name, int index) | 指定索引属性值 |
static Object | getMappedProperty(Object bean, String name) | 获得Map属性 |
static Object | getMappedProperty(Object bean, String name, String key) | 获得Map属性中指定键对应的值 |
static Object | getNestedProperty(Object bean, String name) | 获得嵌套属性 |
static Object | getProperty(Object bean, String name) | 获得属性 |
static PropertyDescriptor | getPropertyDescriptor(Object bean, String name) | 获得属性描述 |
static PropertyDescriptor[] | getPropertyDescriptors(Class<?> beanClass) | 获得属性描述 |
static PropertyDescriptor[] | getPropertyDescriptors(Object bean) | 获得属性描述 |
static Class<?> | getPropertyType(Object bean, String name) | 获得属性类型 |
static Method | getReadMethod(PropertyDescriptor descriptor) | 返回一个可访问的属性的getter方法 |
static Object | getSimpleProperty(Object bean, String name) | 返回属性值 |
static Method | getWriteMethod(PropertyDescriptor descriptor) | 返回一个可访问的属性的setter方法 |
static boolean | isReadable(Object bean, String name) | 判断是否为可读属性 |
static boolean | isWriteable(Object bean, String name) | 判断是否为可写属性 |
static boolean | removeBeanIntrospector(BeanIntrospector introspector) | 移除BeanIntrospector |
static void | resetBeanIntrospectors() | 重置BeanIntrospector |
static void | setIndexedProperty(Object bean, String name, int index, Object value) | 设置指定索引属性值 |
static void | setIndexedProperty(Object bean, String name, Object value) | 设置指定索引属性值 |
static void | setMappedProperty(Object bean, String name, Object value) | 设置Map属性的值 |
static void | setMappedProperty(Object bean, String name, String key, Object value) | 设置Map属性指定键的值 |
static void | setNestedProperty(Object bean, String name, Object value) | 设置嵌套属性的值 |
static void | setProperty(Object bean, String name, Object value) | 设置属性值 |
static void | setSimpleProperty(Object bean, String name, Object value) | 设置属性值 |
使用示例:
package com.gujin.beanutils;import org.apache.commons.beanutils.PropertyUtils;import org.junit.Test;import com.gujin.entity.UserInfo;public class PropertyUtilsTest { @Test public void test() throws Exception { UserInfo userInfo = new UserInfo("jianggujin", "蒋固金"); UserInfo copyed = new UserInfo(); PropertyUtils.copyProperties(copyed, userInfo); System.out.println(copyed); System.out.println(PropertyUtils.describe(userInfo)); PropertyUtils.setProperty(userInfo, "userId", "gjjiang"); System.out.println(userInfo); } }
运行结果:
{userId:jianggujin,userName:蒋固金} {userId=jianggujin, class="class" com.gujin.entity.UserInfo, userName=蒋固金} {userId:gjjiang,userName:蒋固金}
BeanUtils
BeanUtils
通过反射提供了Bean对象的便捷操作方法。
方法摘要:
返回值 | 方法名 | 说明 |
---|---|---|
static Object | cloneBean(Object bean) | 克隆对象 |
static void | copyProperties(Object dest, Object orig) | 复制属性 |
static void | copyProperty(Object bean, String name, Object value) | 复制属性 |
static <K,V> Map<K,V> | createCache() | 创建缓存 |
static Map<String,String> | describe(Object bean) | 描述 |
static String[] | getArrayProperty(Object bean, String name) | 返回指定属性的值,作为字符串数组返回 |
static String | getIndexedProperty(Object bean, String name) | 获取指定索引位置对象作为字符串返回 |
static String | getIndexedProperty(Object bean, String name, int index) | 获取指定索引位置对象作为字符串返回 |
static String | getMappedProperty(Object bean, String name) | 获得Map属性值作为字符串返回 |
static String | getMappedProperty(Object bean, String name, String key) | 获得Map属性中指定键的值作为字符串返回 |
static String | getNestedProperty(Object bean, String name) | 获得嵌套属性作为字符串返回 |
static String | getProperty(Object bean, String name) | 获得属性值作为字符串返回 |
static String | getSimpleProperty(Object bean, String name) | 获得属性值作为字符串返回 |
static void | populate(Object bean, Map<String,? extends Object> properties) | 将Map中的数据注入到Bean对象中 |
static void | setProperty(Object bean, String name, Object value) | 设置属性值 |
使用示例:
package com.gujin.beanutils;import java.util.HashMap;import org.apache.commons.beanutils.BeanUtils;import org.junit.Test;import com.gujin.entity.UserInfo; public class BeanUtilsTest { @Test public void test() throws Exception { UserInfo userInfo = new UserInfo(); HashMapproperties = new HashMap (); properties.put("userId", "jianggujin"); properties.put("userName", "蒋固金"); BeanUtils.populate(userInfo, properties); System.out.println(userInfo); } }
运行结果:
{userId:jianggujin,userName:蒋固金}
ConvertUtils
ConvertUtils
提供了数据类型相互转换的方法。
方法摘要:
方法摘要:返回值 | 方法名 | 说明 |
---|---|---|
static String | convert(Object value) | 将对象转换为字符串 |
static Object | convert(Object value, Class<?> targetType) | 将对象转换为指定数据类型对象 |
static Object | convert(String[] values, Class<?> clazz) | 将数组转换为指定数据类型对象 |
static Object | convert(String value, Class<?> clazz) | 将字符串转换为指定数据类型对象 |
static void | deregister() | 移除所有已经注册的转换器 |
static void | deregister(Class<?> clazz) | 移除指定类型的转换器 |
static Converter | lookup(Class<?> clazz) | 查找指定类型的转换器 |
static Converter | lookup(Class<?> sourceType, Class<?> targetType) | 查找将指定类型转换为另一种类型的转换器 |
static void | register(Converter converter, Class<?> clazz) | 注册转换器 |
使用示例:
package com.gujin.beanutils;import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.Date;import org.apache.commons.beanutils.ConvertUtils; import org.apache.commons.beanutils.Converter; import org.junit.Test; public class ConvertUtilsTest { @Test public void test() throws Exception { ConvertUtils.register(new Converter() { @Override publicT convert(Class arg0, Object arg1) { try { return (T) new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") .parse((String) arg1); } catch (ParseException e) { return null; } } }, Date.class); System.out.println(ConvertUtils .convert("2016-04-09 12:41:00", Date.class)); } }
运行结果:
Sat Apr 09 12:41:00 CST 2016