定义切点方法所用的接口

package com.lsz.config.enums;
 
 
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
 
 
/**
* 加载配置注解
*
* @author zyl
* @date 2022/5/13 16:34
*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LoadConfig {
}

配置增强的方法


package com.lsz.config.aop;
 
 
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
 
 
/**
* @author zyl
* @date 2022/5/13 16:34
*/
@Aspect
@Component
public class LoginConfigAspect {
 
 
    /**
     * 需要加载配置的切点
     */
    @Pointcut(value = "@annotation(com.lsz.config.enums.LoadConfig) && args(..)")
    public void LoadingConfigPointAut() {
    }
 
 
    /**
     * 前置执行刷新配置
     * @param joinPoint
     * @return
     */
    @Before(value = "LoadingConfigPointAut()")
    public void LoadingConfig(JoinPoint joinPoint) {
        System.out.println("前置执行刷新配置通知执行");
    }
}

最后在你需要拦截的方法上加上你自定义的接口


@LoadConfig
@ResponseBody
@RequestMapping("loginTest")
   public Object loginTest(){
   System.out.println("测试接口");
   return new Object();
}

经测试:不管在@Before前置增强还是在需要增强方法里面抛出异常,出现错误,@after后置增强方法都会执行,而且在异常抛出之前执行。


版权声明:本文为qq_45148387原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/qq_45148387/article/details/124754902