定义切点方法所用的接口
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后置增强方法都会执行,而且在异常抛出之前执行。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)