需求:从数据库获取一个实体类数据,并以Map的形式下载数据到Excel;
解决办法:
Controller层获取到实体类对象后,显式的get实体类的成员变量;
具体做法如下:
Person person = personService.getPersonBy**(Object param);
Map<String,Object> personObject = new HashMap<>();
personObject.put("name",person.getName());
personObject .put("gender".person.getGender());
personObject .put("age",person.getAge());
// 省略文件下载的处理
反思:
假如说该实体类有100个成员变量呢?这样做显然不可以,代码臃肿,耦合度高,还有什么更好的解决方案么?可以使用反射。
反射概念:
JAVA中反射是动态获取信息以及动态调用对象方法的一种反射机制。
Java反射就是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;并且能改变它的属性。而这也是Java被视为动态语言的一个关键性质。
具体实现:
Map<String,Object> map = new TreeMap<>();
Person person = personService.getPersonBy**(Object param);
Field[] fields = person.getClass().getDeclaredFields();//Get all field
for (Field field: fields){
//Set the access rights of the object to ensure access to the private field
field.setAccessible(true);
map.put(field.getName(),field.get(person));
}