springboot详细记录业务修改内容,包含修改前后具体字段的值的具体变化

424 阅读1分钟

1、定义一个注解

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
public @interface EnableGameleyLog {
    /**
     * 操作的中文说明 可以直接调用ModifyName
     * @return
     */
    String name() default "";

    /**
     * 获取编辑信息的解析类,目前为使用id获取,复杂的解析需要自己实现,默认不填写
     * 则使用默认解析类
     * @return
     */
    Class parseclass() default DefaultContentParse.class;

    /**
     * 查询数据库所调用的class文件
     * @return
     */
    Class serviceclass() default IService.class;

    /**
     * 前台字段名称
     */
    String[] feildName() default {"id"};

}

2、简单使用在方法

@EnableGameleyLog(name = ModifyName.SAVE,serviceclass = DemoService.class)
public BaseResponse addDemo(@RequestBody Demo demo){
   ...
}

3、写解析类,默认的解析类为使用id查询

 
/**
 * 基础解析类
 * 单表编辑时可以直接使用id来查询
 * 如果为多表复杂逻辑,请自行编写具体实现类
 */
public class DefaultContentParse implements ContentParser {
    @Override
    public Object getResult(Map<String,Object> feildValues, EnableGameleyLog enableGameleyLog) {
        if(!feildValues.containsKey("id")){
            logger.error("未解析到id值,请检查前台传递参数是否正确");
        }
        Object result= feildValues.get("id");
        Integer id=0;
        if(result instanceof String){
            id= Integer.parseInt((String) result);

        }else if(result instanceof Integer){
            id= (Integer) result;
        }
        IService service= null;
        Class cls=enableGameleyLog.serviceclass();
        service = (IService) SpringUtil.getBean(cls);

        return  service.selectById(id);
    }


}

设计实现思路,大概就是注解 + 事务 + 反射 如何获取历史数据做对比、还有复杂的嵌套对比? 自己实现复杂逻辑 注意注解的定义等

public @interface {
    ...
    // 具体业务操作名称 
    String handleName() default "";
    // 获取编辑信息的解析类,目前为使用id获取,复杂的解析需要自己实现,默认不填写则使用默认解析类 Class 
    parseclass() default DefaultContentParse.class;
    // 查询数据库所调用的class文件 
    Class serviceclass() default IService.class;
    ...
    自己扩展

} 别人的地址,自己懒得写 项目地址