代码:

  ObjectUtil类:

import java.lang.reflect.Field;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* 利用Java反射机制对实体类的常用操作
* @author 【】
*
*/
public class ObjectUtil { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd"); SimpleDateFormat sfCsv = new SimpleDateFormat("yyyyMMdd"); /**
* 根据类的名称获取类的属性信息(不包括父类)
*/
public List<Field> getFields(String className) throws ClassNotFoundException {
List<Field> list = new ArrayList<>();
Class<?> clazz = Class.forName(className);
Field[] fields = clazz.getDeclaredFields();
list.addAll(Arrays.asList(fields)); return list;
} /**
* 根据类的名称获取属性信息和父类的属性信息
*/
public List<Field> getAllFields(String className) throws ClassNotFoundException {
List<Field> list = new ArrayList<>();
Class<?> clazz = Class.forName(className);
Field[] fields = clazz.getDeclaredFields();
list.addAll(Arrays.asList(fields));
Class<?> superClazz = clazz.getSuperclass();
if (superClazz != null) {
Field[] superFields = superClazz.getDeclaredFields();
list.addAll(Arrays.asList(superFields));
}
return list;
} /**
* 根据类名和字段名获取字段在类中的类型
*/
public String getFieldClassName(String className ,String fieldName) throws ClassNotFoundException {
Class<?> clazz = Class.forName(className);
Field[] fields = clazz.getDeclaredFields();
for (Field field : fields) {
if (field.getName().equals(fieldName)) {
return field.getType().getSimpleName();
}
}
return "";
} /**
* 获取传入对象的指定属性的值
*/
public String getValueByPropName(Object obj, String propName) {
String value = null;
try {
// 获取对象的属性
Field field = obj.getClass().getDeclaredField(propName);
// 对象的属性的访问权限设置为可访问
field.setAccessible(true);
value = field.get(obj).toString();
} catch (Exception e) {
return null;
} return value;
} /**
* 根据传入对象获取其属性、类型、属性值的集合
*/
public List<Map<String, Object>> getFiledsInfo(Object o) {
Field[] fields = o.getClass().getDeclaredFields();
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
Map<String, Object> infoMap = null;
for (int i = 0; i < fields.length; i++) {
infoMap = new HashMap<String, Object>();
infoMap.put("type", fields[i].getType().toString());
infoMap.put("name", fields[i].getName());
infoMap.put("value", getValueByPropName(o, fields[i].getName()));
list.add(infoMap);
}
return list;
} /**
* 根据类的名称获取该类和该注解值的map集合(包括父类)
* (注:注解Comment是为代码完整自定义的注解,可根据实际需求要获取的注解直接替换即可)
*/
public Map<String, String> getAnnotationVal(String className) {
Map<String, String> map = new HashMap<>();
try {
List<Field> lists = getAllFields(className);
for (Field field : lists) {
// 设置访问对象权限,保证对私有属性的访问
field.setAccessible(true);
// 判断该字段是否存在@Comment注解
if (!field.isAnnotationPresent(Comment.class)) {
continue;
}
// 获取字段中对应的注解@Comment对象
Comment comment = field.getAnnotation(Comment.class);
// 获取自定义注解的值
String value = comment.value();
if (value != null && !"".equals(value)) {
map.put(field.getName(), value);
}
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return map;
} /**
* 判断该类是否存在该属性(不包括父类)
*/
public boolean existsField(String className, String fieldName) throws ClassNotFoundException {
boolean flag = false;
Class<?> clazz = Class.forName(className);
Field[] fields = clazz.getDeclaredFields();
for (Field field : fields) {
if (field.getName().equals(fieldName)) {
flag = true;
break;
}
}
return flag;
} /**
* 给该类的该字段设值
*/
public void setFieldValue(String fieldName, String fieldValue, Object object) {
Field field = null;
try {
boolean isExist = false;
Field[] fields = object.getClass().getDeclaredFields();
for (Field var : fields) {
if (var.getName().equals(fieldName)) {
isExist = true;
field = object.getClass().getDeclaredField(fieldName);
break;
}
} if (!isExist) {
field = object.getClass().getSuperclass().getDeclaredField(fieldName);
}
// 设置对象的访问权限,保证对private的属性的访问
field.setAccessible(true); if ("class java.math.BigDecimal".equals(field.getType().toString())) {
field.set(object, new BigDecimal(fieldValue.trim()));
} else if ("Date".equals(field.getType().getSimpleName())) {
if (fieldValue.toString().indexOf("/") > 0) {
fieldValue = fieldValue.toString().replace('/', '-');
}
if (fieldValue.toString().length() == 8) {
Date date = sfCsv.parse(fieldValue.toString());
field.set(object, date);
} else if (fieldValue.toString().length() == 10) {
Date date = sf.parse(fieldValue.toString());
field.set(object, date);
} else {
Date date = sdf.parse(fieldValue.toString());
field.set(object, date);
}
// field.set(object, sdf.parse(fieldValue));
} else if ("class java.lang.Integer".equals(field.getType().toString())) {
field.set(object, Integer.valueOf(fieldValue));
} else {
field.set(object, fieldValue);
}
} catch (Exception e) { }
} public static void main(String[] args) throws Exception {
ObjectUtil util = new ObjectUtil(); /*List<Field> fields = util.getFields(Student.class.getName());
for (Field field : fields) {
// 设置访问对象权限,保证对私有属性的访问
field.setAccessible(true);
System.out.println(field.getName());
}*/ /*List<Field> fields = util.getAllFields(Student.class.getName());
for (Field field : fields) {
// 设置访问对象权限,保证对私有属性的访问
field.setAccessible(true);
System.out.println(field.getName());
}*/ /*String str = util.getFieldClassName(Student.class.getName(), "name");
System.out.println(str);*/ /*Student stu = new Student();
stu.setName("Jack");
stu.setSex("男");
String value = util.getValueByPropName(stu, "name");
System.out.println(value);*/ /*Student stu = new Student();
stu.setName("Jack");
stu.setSex("男");
List<Map<String, Object>> lists = util.getFiledsInfo(stu);
for (Map<String, Object> map : lists) {
System.out.println(map.get("name"));
System.out.println(map.get("type"));
System.out.println(map.get("value"));
}*/ /*Map<String, String> map = util.getAnnotationVal(Student.class.getName());
for (String key : map.keySet()) {
System.out.println(map.get(key) + "——————" + key);
}*/ /*boolean flag = util.existsField(Student.class.getName(), "name");
System.out.println(flag);*/ Student stu = new Student();
util.setFieldValue("name", "Rose", stu);
System.out.println(stu.getName());
}
}

  测试实体类Student:

public class Student {

	@Comment(value = "姓名")
private String name; @Comment(value = "性别")
private String sex; @Comment(value = "年龄")
private String age; @Comment(value = "班级")
private String stuClass; public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
public String getStuClass() {
return stuClass;
}
public void setStuClass(String stuClass) {
this.stuClass = stuClass;
} }

  测试自定义注解@Comment:

import static java.lang.annotation.RetentionPolicy.RUNTIME;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
/**
* 自定义属性注解
* @author 【】
*
*/
@Target({ ElementType.FIELD, ElementType.TYPE })
@Retention(RUNTIME)
public @interface Comment {
// 定义注解中的属性,默认值为空字符串
String value() default "";
}

利用Java反射机制对实体类的常用操作工具类ObjectUtil的更多相关文章

  1. 利用java反射机制 读取配置文件 实现动态类载入以及动态类型转换

    作者:54dabang 在spring的学习过程之中,我们能够看出通过配置文件来动态管理bean对象的优点(松耦合 能够让零散部分组成一个总体,而这些总体并不在意之间彼此的细节,从而达到了真正的物理上 ...

  2. 利用JAVA反射机制设计通用的DAO

    利用JAVA反射机制设计一个通用的DAO 反射机制 反射机制指的是程序在运行时能够获取自身的信息.在java中,只要给定类的名字,    那么就可以通过反射机制来获得类的所有信息. 反射机制创建类对象 ...

  3. 利用Java反射机制将Bean转成Map

    import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang ...

  4. Java反射机制demo(四)—获取一个类的父类和实现的接口

    Java反射机制demo(四)—获取一个类的父类和实现的接口 1,Java反射机制得到一个类的父类 使用Class类中的getSuperClass()方法能够得到一个类的父类 如果此 Class 表示 ...

  5. 利用java反射机制实现读取excel表格中的数据

    如果直接把excel表格中的数据导入数据库,首先应该将excel中的数据读取出来. 为了实现代码重用,所以使用了Object,而最终的结果是要获取一个list如List<User>.Lis ...

  6. 利用java反射机制编写solr通用的java客户端

    一.前言 通过上一篇的讲解,我们知道了dynamicFiled字段,它是动态的,不需要显示的声明.而且一些常用的基本类型solr已经默认给我们创建好了. 例如:*_i,*_is,等. 如果我们要使用动 ...

  7. 不使用BeanUtils,利用Java反射机制:表单数据自动封装到JavaBean

    在百度搜“java反射 将表单数据自动封装到javabean ”,第一页显示的都是一样的代码,都是利用导入第三方jar包<commons-beanutils>和<commons-lo ...

  8. 利用Java反射机制优化简单工厂设计模式

    之前项目有个需求,审批流程的时候要根据配置发送信息:发送短信.发送邮件.当时看到这个就想到要用工厂模式,为什么要用工厂模式呢?用工厂模式进行大型项目的开发,可以很好的进行项目并行开发.就是一个程序员和 ...

  9. 利用JAVA反射机制将JSON数据转换成JAVA对象

    net.sf.json.JSONObject为我们提供了toBean方法用来转换为JAVA对象, 功能更为强大,  这里借鉴采用JDK的反射机制, 作为简单的辅助工具使用,   有些数据类型需要进行转 ...

随机推荐

  1. 路飞学城Python-Day153

    Scrapy核心组件

  2. 两个sed小技巧:sed "/变量/变量/"

    两个sed小技巧 在写shell时使用sed处理一些输出,遇到两个问题,在网上找到了相应的解决办法,在此处备份一下. [ sed处理空字符 ] 空字符,它的ASCII码值为0.在sed中如何标识空字符 ...

  3. BZOJ 3158 千钧一发 (最大流->二分图带权最大独立集)

    题面:BZOJ传送门 和方格取数问题很像啊 但这道题不能像网格那样黑白染色构造二分图,所以考虑拆点建出二分图 我们容易找出数之间的互斥关系,在不能同时选的两个点之间连一条流量为$inf$的边 由于我们 ...

  4. django视图的定义

    概述 视图:视图的本质就是一个python中的函数,作用是接收web请求,并响应web请求. 过程:django获取浏览器输入的url,经过django中的url管理器匹配到对应的视图函数,视图管理器 ...

  5. 【codeforces 807C】Success Rate

    [题目链接]:http://codeforces.com/contest/807/problem/C [题意] 给你4个数字 x y p q 要求让你求最小的非负整数b; 使得 (x+a)/(y+b) ...

  6. 在android平台打印C语言日志

    在android平台打印C语言日志 1.操作平台:AS2.0 2.步骤如下: 在C代码中添加如下代码: #define LOG_TAG "我的C语言日志:" #define LOG ...

  7. Docker学习总结(14)——从代码到上线, 云端Docker化持续交付实践

    2016云栖大会·北京峰会于8月9号在国家会议中心拉开帷幕,在云栖社区开发者技术专场中,来自阿里云技术专家罗晶(瑶靖)为在场的听众带来<从代码到上线,云端Docker化持续交付实践>精彩分 ...

  8. [SharePoint][SharePoint Designer 入门经典]Chapter11 工作流基础

    1.SPS中可以创建的工作流的种类 2.SPD工作流基础 3.创建列表\库工作流 4.创建可重用的工作流 5.利用基于站点的工作流 6.SPD 工作流的限制和注意事项

  9. 用 query 方法 获得xml 节点的值

    DECLARE @result xml SET @result='<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelo ...

  10. HDU 2838 (树状数组求逆序数)

    题意: 给你N个排列不规则的数(1~N),任务是把它从小到大排好,每次仅仅能交换相邻两个数,交换一次的代价为两数之和.求最小代价 思路:对于当前数X.我们如果知道前面比它大的数有多少,如果为K,那么有 ...