zoukankan      html  css  js  c++  java
  • spring boot (6) AOP的使用

    常用AOP通知(增强)类型

          * 1. 前置通知:在方法调用之前执行
         * 2. 后置通知:在方法正常调用之后执行
         * 3. 环绕通知:在方法调用之前和之后,都分别可以执行的通知
         * 4. 异常通知:如果在方法调用过程中发生异常,则通知
         * 5. 最终通知:在方法调用之后执行
    切面表达式:
         * execution 代表所要执行的表达式主体
         * 第一处 * 代表方法返回类型 *代表所有类型
         * 第二处 包名代表aop监控的类所在的包
         * 第三处 .. 代表该包以及其子包下的所有类方法
         * 第四处 * 代表类名,*代表所有类
         * 第五处 *(..) *代表类中的方法名,(..)表示方法中的任何参数
       @Around("execution(* com.imooc.service.impl..*.*(..))")

    使用类:

    package com.im.aspect;
    
    import org.aopalliance.intercept.Joinpoint;
    import org.aspectj.lang.ProceedingJoinPoint;
    import org.aspectj.lang.annotation.Around;
    import org.aspectj.lang.annotation.Aspect;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.stereotype.Component;
    
    @Aspect
    @Component
    public class ServiceLogAspect {
    
        public static final Logger log =
                LoggerFactory.getLogger(ServiceLogAspect.class);
    
        /**
         * AOP通知:
         * 1. 前置通知:在方法调用之前执行
         * 2. 后置通知:在方法正常调用之后执行
         * 3. 环绕通知:在方法调用之前和之后,都分别可以执行的通知
         * 4. 异常通知:如果在方法调用过程中发生异常,则通知
         * 5. 最终通知:在方法调用之后执行
         */
    
        /**
         * 切面表达式:
         * execution 代表所要执行的表达式主体
         * 第一处 * 代表方法返回类型 *代表所有类型
         * 第二处 包名代表aop监控的类所在的包
         * 第三处 .. 代表该包以及其子包下的所有类方法
         * 第四处 * 代表类名,*代表所有类
         * 第五处 *(..) *代表类中的方法名,(..)表示方法中的任何参数
         *
         * @param joinPoint
         * @return
         * @throws Throwable
         */
        @Around("execution(* com.imooc.service.impl..*.*(..))")
        public Object recordTimeLog(ProceedingJoinPoint joinPoint) throws Throwable {
    
            log.info("====== 开始执行 {}.{} ======",
                            joinPoint.getTarget().getClass(),
                            joinPoint.getSignature().getName());
    
            // 记录开始时间
            long begin = System.currentTimeMillis();
    
            // 执行目标 service
            Object result = joinPoint.proceed();
    
            // 记录结束时间
            long end = System.currentTimeMillis();
            long takeTime = end - begin;
    
            if (takeTime > 3000) {
                log.error("====== 执行结束,耗时:{} 毫秒 ======", takeTime);
            } else if (takeTime > 2000) {
                log.warn("====== 执行结束,耗时:{} 毫秒 ======", takeTime);
            } else {
                log.info("====== 执行结束,耗时:{} 毫秒 ======", takeTime);
            }
    
            return result;
        }
    
    }
  • 相关阅读:
    OS X EI Capitan 安装mysql-5.7.9
    CAS SSO
    单点登录SSO
    videojs 视频开发API
    NodeJS无所不能:细数10个令人惊讶的NodeJS开源项目
    程序员使用Node的十个技巧
    pdf 回退快捷键
    公式神器 Mathpix Snip 比mathtype快
    AI studio 尝试
    tmux 使用
  • 原文地址:https://www.cnblogs.com/guangzhou11/p/12216760.html
Copyright © 2011-2022 走看看