专业的JAVA编程教程与资源

网站首页 > java教程 正文

java自定义日志注解(自定义注解实现日志)

temp10 2024-09-27 23:03:06 java教程 9 ℃ 0 评论

日志记录是一件很有意义的事情,通过日志可以记录当前用户做了哪些操作。对当前所做的操作进行描述以及记录。

可以发现记录用户当前做了哪些操作是一个公共方法,是否单独写一个工具类,然后每次调用该工具类中的方法呢?显然这种方式不太友好,可扩展性不强。我们可以有更好的设计,可以利用Spring的AOP特性,在某一点进行方法增强。

java自定义日志注解(自定义注解实现日志)

具体的实现:

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD, ElementType.PARAMETER})
public @interface LogOpt {
    String desc() default "";
}
@Component
@Slf4j
@Aspect
public class LogAspect {
    @Autowired
    private LogDescPoMapper iLogMapper;

    /***
     * 定义一个连接点
     */
    @Pointcut("execution(* cn.zdm.demo2.auth.controller.*.*(..)) && @annotation(cn.zdm.demo2.common.log.LogOpt)")
    public void log() {

    }

    /***
     * 前置通知:在我们目标方法执行之前
     */
    @Before("log()")
    public void before(JoinPoint joinPoint) {
        log.info("执行了LogOptAspect的前置通知");
        MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
        Method method = methodSignature.getMethod();
        save(method);
    }

    /***
     * 后置通知:无论是否发生异常,都将会收到通知
     */
    @After("log()")
    public void after() {
        log.info("执行了目标方法的后置通知");
    }

    /***
     * 返回通知:在我们正常执行后通知
     */
    @AfterReturning("log()")
    public void afterReturn() {
        log.info("执行正常");
    }

    /***
     * 异常通知
     */
    @AfterThrowing("log()")
    public void afterThrowing() {
        log.error("执行异常");
    }

    /***
     *目标方法的调用由环绕通知决定,即你可以决定是否调用目标方法,joinPoint.procced()就是执行目标方法的代码 。环绕通知可以控制返回对象
     */
    @Around("log()")
    public void around() {
        log.info("====>环绕通知");
        return;
    }

    @Async
    public void save(Method method) {
        //判断方法上的注解
        if (!method.isAnnotationPresent(LogOpt.class)) {
            return;
        }
        //获取注解上的参数值
        LogOpt logOpt = method.getAnnotation(LogOpt.class);
        LogDescPO optLog = LogDescPO.builder()
                .id(UUID.randomUUID().toString())
                .userName("test")
                .description(logOpt.desc())
                .visitTime(new Date()).build();
        iLogMapper.insert(optLog);
        return;
    }
}
    @ApiOperation(value = "批量添加app信息")
    @RequestMapping(value = "/save/app", method = RequestMethod.GET)
    @LogOpt(desc = "批量添加app信息")
    public ResultObject<Object> saveApp() {
        // List<IosAppPO> list = new ArrayList<>();
        IosAppPO iosAppPO;
        for (int i = 10; i < 20; i++) {
            iosAppPO = new IosAppPO();
            iosAppPO.setAppCreator("zhaodeman");
            iosAppPO.setAppName("应用" + i);
            iosAppPO.setAppLoseTime(new Date());
            iosAppPO.setAppCreateTime(new Date());
            iosAppService.saveIosApp(iosAppPO);
            // list.add(iosAppPO);
        }
        return ResultResponse.success("批量添加app信息成功");
    }
@ApiOperation("查询所有的日志记录")
    @GetMapping("/log/queryAll")
    public ResultObject<Object> queryAllLog() {
        List<LogDescPO> result = logDescPoMapper.queryAllLog();
        return ResultResponse.success("查询日志成功", result.size(), result);
    }

这样就可以实现扩展的日志记录操作。

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表