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技术与相关干货分享,回复关键字获取对应干货,本文版权归作者软件老王所有,转载需注明作者、超链接,否则保留追究法律责任的权利。
原文地址:https://www.cnblogs.com/ruanjianlaowang/p/15603820.html