定义一个切面日志

spring 文章 2024-03-25 10:11 415 0 全屏看文

AI助手支持GPT4.0

我们可以通过aspect进行无侵入式的日志记录,

具体代码如下:

定义一个注解

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface LogOperation {
    String value() default "";
}

我们定义一个切面处理类。

并定义切面,然后,通过@Around("logPointCut()")注解,你定义了一个环绕通知(Around Advice),它将围绕着上述切点定义的方法执行。这意味着,每当有方法被@LogOperation注解标记,并被调用时,around方法就会被触发。在这个方法内部,你可以在目标方法执行前后添加自定义逻辑,比如记录日志、计算执行时间等。

/**
* 系统⽇志,切⾯处理类
*/
@Aspect
@Component
public class LogOperationAspect {
    @Autowired
    private SysLogOperationService sysLogOperationService;
    
    @Pointcut("@annotation(cn.sanshu.common.annotation.LogOperation)")
    public void logPointCut() {
        
   }
    
    @Around("logPointCut()")
    public Object around(ProceedingJoinPoint point) throws Throwable {
        long beginTime = System.currentTimeMillis();
        try {
            //执⾏⽅法
            Object result = point.proceed();
            
            //执⾏时⻓(毫秒)
            long time = System.currentTimeMillis() - beginTime;
            //保存⽇志
            saveLog(point, time, OperationStatusEnum.SUCCESS.value());
            
            return result;
       }catch(Exception e) {
            //执⾏时⻓(毫秒)
            long time = System.currentTimeMillis() - beginTime;
            //保存⽇志
            saveLog(point, time, OperationStatusEnum.FAIL.value());
            
            throw e;
       }
   }
    
    private void saveLog(ProceedingJoinPoint joinPoint, long time,
Integer status) {
        //逻辑对象处理
        
        //保存到DB
        sysLogOperationService.save(log);
   }
}


使用:

image.png

-EOF-

AI助手支持GPT4.0


国内超级便宜服务器

摸鱼人热门新闻聚合

钻级赞助商 我要加入

开发者在线工具

第三方支付技术请加QQ群

相关文章
SpringBoot最简多线程配置教程
Spring jdbctemplate执行插入语句获取id的方法
Spring里自带的数组集合用逗号拼接成字符串的方法
java一行代码判断2个数组里是否有相同的值
定义一个切面日志
随便看看
阿里云com、cn域名续费优惠码(2020年3月可用) 2776
线上防疫题库正确答案 2840
线上防疫题库正确答案(多选题) 4728
微信设置不可以使用小程序(游戏小程序) 5511
adsense申请已经支付的订单回退的网址 3123
BT面板查看网站入口、账号密码的命令 5875
ucloud海外服务器超级优惠券 3178
根据您的消费情况,您的延停权益已发生变化,变更后的延停权益为延停额度20.00元 5730
为什么我们喜欢迈克尔杰克逊。 4065
阿里云com、cn域名续费优惠码(2020年5月可用) 3489