业务需求:项目中的配置信息,关系到程序跑出来数据准确性,需要记录下什么人、什么时间、修改了什么字段,原来值、最新值,以便回溯,防止扯皮,内部打“官司”用。
2、解决方案通过java反射,后台程序比对前端传入值与数据库中值,并记录下来;
2.1 测试实体类import lombok.Getter; import lombok.Setter; @Setter @Getter public class User { private String name; private String des; }
**简要说明:**创建测试类User,两个属性;
2.2 工具类import java.beans.PropertyDescriptor; import java.lang.reflect.Field; import java.lang.reflect.Method; public class Utils { public staticString compareObject(Object oldBean, Object newBean) { String str = ""; T pojo1 = (T) oldBean; T pojo2 = (T) newBean; try { Class clazz = pojo1.getClass(); Field[] fields = pojo1.getClass().getDeclaredFields(); int i = 1; for (Field field : fields) { PropertyDescriptor pd = new PropertyDescriptor(field.getName(), clazz); Method getMethod = pd.getReadMethod(); Object o1 = getMethod.invoke(pojo1); Object o2 = getMethod.invoke(pojo2); if (o1 == null || o2 == null) { continue; } if (!o1.toString().equals(o2.toString())) { if (i != 1) { str += ";"; } str += i + "、字段:" + field.getName() + ",旧值:" + o1 + ",新值:" + o2; i++; } } } catch (Exception e) { e.printStackTrace(); } return str; } public static void main(String[] args) { User user1 = new User(); user1.setName("老王"); user1.setDes("帅哥"); User user2 = new User(); user2.setName("老王"); user2.setDes("靓仔"); String result = compareObject(user1,user2); System.out.println(result); } }
简要说明:
(1)入参,对象类型要一致;
(2)其中的invoke是获取具体比对值,pojo1和pojo2是传入对象;
从效果图可以看出来,已经可以记录变更值了;
需求补充:因为从前端过来的是json格式的数据,字段是都是英文的,例如截图中的des,对应页面的展示字段,不一定能对的上,使用自定义注解,转成中文备注记录;
2.4 自定义注解import java.lang.annotation.*; @documented @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.FIELD}) public @interface ColumnConf { String value() default ""; }
自定义注解;
2.5 自定义注解使用到实体类上@Setter @Getter public class User { @ColumnConf("名字") private String name; @ColumnConf("描述") private String des; }2.6 工具方法稍微做下改动,增加一行,修改下取值,其他不动
ColumnConf columnConf = field.getAnnotation(ColumnConf.class); str += i + "、字段:" + columnConf.value() + ",旧值:" + o1 + ",新值:" + o2;2.7 改造后效果图: 2.8 说明
至于保存log,就不多说了,创建个log表存一下就好了。。
更多信息请关注公众号:「软件老王」,关注不迷路,软件老王和他的IT朋友们,分享一些他们的技术见解和生活故事。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)