java项目,记录页面修改值,内部打“官司”用
1、问题描述
业务需求:项目中的配置信息,关系到程序跑出来数据准确性,需要记录下什么人、什么时间、修改了什么字段,原来值、最新值,以便回溯,防止扯皮,内部打“官司”用。
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 static<T> String 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是传入对象;

2.3 效果图

从效果图可以看出来,已经可以记录变更值了;
需求补充:因为从前端过来的是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朋友们,分享一些他们的技术见解和生活故
    更多信息请关注公众号:「软件老王」,关注不迷路,IT技术与相关干货分享,回复关键字获取对应干货,本文版权归作者软件老王所有,转载需注明作者、超链接,否则保留追究法律责任的权利。
 
  
 
  
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号