工具类:UpdateLogUtil.java
package com.newsee.util;
import java.lang.annotation.Annotation;
import java.lang.reflect.Field;
import java.math.BigDecimal;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import javax.xml.bind.annotation.XmlElement;
public class UpdateLogUtil {
public static String UpdateLog(Object obj_old,Object obj_new) throws Exception {
Class clas_old = obj_old.getClass();
Class clas_new = obj_new.getClass();
if(!(clas_old.isInstance(obj_new))){
System.out.println("UpdateLogUtil.UpdateLog:传入的两个java对象类型不一致!");
return "UpdateLogUtil.UpdateLog:传入的两个java对象类型不一致!";
}
Field[] fields = clas_old.getFields();
String remark = "";
for (Field field : fields) {
String name = field.getName();
String type = field.getType().getName();
field.setAccessible(true); //设置些属性是可以访问的
Object val_old = field.get(obj_old);//得到此属性的修改前值
Object val_new = field.get(obj_new);//得到此属性的修改后值
//bigdecimal 类型的数据要去掉小数点后尾部的0不一致造成数据比对差异
if(type.equals("java.math.BigDecimal") && val_old!=null && val_new!=null ){
BigDecimal val_old_big = new BigDecimal(String.valueOf(val_old));
BigDecimal val_new_big = new BigDecimal(String.valueOf(val_new));
if(String.valueOf(val_old_big).indexOf(".")!= -1 || String.valueOf(val_new_big).indexOf(".")!= -1 ){//由于无法获取精度值,只能对所有带小数点的数据进行处理
DecimalFormat formatter1=new DecimalFormat("0.00");
val_old = formatter1.format(val_old_big);
val_new = formatter1.format(val_new_big);
}
}
//DATE 类型的数据要格式化
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
if(type.equals("java.util.Date")){
if (val_old != null) {
val_old = sdf.format(val_old)+";";
}
if (val_new != null) {
val_new = sdf.format(val_new)+";";
}
}
if(!String.valueOf(val_old).equals(String.valueOf(val_new))){
//保存处理数据
System.out.println("UpdateLogUtil.UpdateLog:"+name+"--"+val_old+"----"+val_new);
//1、获取属性上的指定类型的注解
Annotation annotation = field.getAnnotation(XmlElement.class);
//有该类型的注解存在
if (annotation!=null) {
//强制转化为相应的注解
XmlElement xmlElement = (XmlElement)annotation;
//3、获取属性上的指定类型的注解的指定方法
String str_val_old = "",str_val_new = "";
if (!"null".equals(String.valueOf(val_old))) {
str_val_old = String.valueOf(val_old);
}
if (!"null".equals(String.valueOf(val_new))) {
str_val_new = String.valueOf(val_new);
}
if (xmlElement.name().equals("##default")) {
System.out.println("UpdateLogUtil.UpdateLog:属性【"+name+"】注解使用的name是默认值: "+xmlElement.name());
remark += xmlElement.name()+"修改前:" + str_val_old+"、修改后:"+str_val_new+";";
}else {
System.out.println("UpdateLogUtil.UpdateLog:属性【"+name+"】注解使用的name是自定义的值: "+xmlElement.name());
remark += xmlElement.name()+"修改前:" + str_val_old+"、修改后:"+str_val_new+";";
}
}
}
}
return remark;
}
}
ps:关于上面标红的getFields()
关于获取类的字段有两种方式:getFields()和getDeclaredFields()。我们先来看看这两者的区别吧:
getFields():获得某个类的所有的公共(public)的字段,包括父类中的字段。
getDeclaredFields():获得某个类的所有声明的字段,即包括public、private和proteced,但是不包括父类的申明字段。
同样类似的还有getConstructors()和getDeclaredConstructors()、getMethods()和getDeclaredMethods(),这两者分别表示获取某个类的方法、构造函数。
在要记录日志的对象中,添加注解:
public class LegalUnit implements Serializable{
private static final long serialVersionUID = 1L;
private Long iD;
@XmlElement(name = "名称")
public String name;
@XmlElement(name = "责任单位")
public String departmentID;
@XmlElement(name = "所在城市")
public Integer province;
private String provinceName;
@XmlElement(name = "所在区县")
public Integer city;
private String cityName;
@XmlElement(name = "注册地址")
public String regAddress;
@XmlElement(name = "经营范围")
public String manageRange;
@XmlElement(name = "注册资本(万元)")
public BigDecimal regFund;
@XmlElement(name = "设立日期")
@JSONField(format="yyyy-MM-dd")
public Date setUpDate;
@XmlElement(name = "经营期限开始")
@JSONField(format="yyyy-MM-dd")
public Date manageBeginDate;
@XmlElement(name = "经营期限结束")
@JSONField(format="yyyy-MM-dd")
public Date manageEndDate;
@XmlElement(name = "营业执照类型")
public String businessType;
@XmlElement(name = "统一社会信用代码")
public String businessCode;
.......
}
最后在具体的业务逻辑中调用工具类即可:
String a = UpdateLogUtil.UpdateLog(lg,legalUnit);