spring aop
Last updated on January 18, 2025 am
🧙 Questions
通过spring aop注入,实现监听service整个生命周期。
☄️ Ideas
添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
implementation 'org.springframework.boot:spring-boot-starter-aop'
创建注解WatchDog
建议在
annotation
目录下创建注解
@Target(value = {ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface WatchDog {
String who() default "ispong";
}
解析注解
通常以
Aspect
为命名结尾
@Aspect
@Component
@Slf4j
public class WatchDogAspect {
/*
* 指定需要解析的注解
*
* @ispong
*/
@Pointcut("@annotation(com.isxcode.leo.demo.spring.aop.annotation.WatchDog)")
public void watchDogOperate() {
}
@Before(value = "watchDogOperate()&&@annotation(watchDog)")
public void before(JoinPoint joinPoint, WatchDog watchDog) {
log.info("2:before");
String username = spelParseUsername(joinPoint, watchDog.who());
log.info("3:username {}", username);
}
@AfterReturning(value = "watchDogOperate()&&@annotation(watchDog)")
public void afterReturning(JoinPoint joinPoint, WatchDog watchDog) {
log.info("5:afterReturning");
}
@AfterThrowing(value = "watchDogOperate()&&@annotation(watchDog)")
public void afterThrowing(JoinPoint joinPoint, WatchDog watchDog) {
log.info("afterThrowing");
}
@After(value = "watchDogOperate()&&@annotation(watchDog)")
public void after(JoinPoint joinPoint, WatchDog watchDog) {
log.info("6:after");
}
@Around(value = "watchDogOperate()")
public Object around(ProceedingJoinPoint pjp) throws Throwable {
log.info("1:around");
// 开始执行service中的方法
Object retVal = pjp.proceed();
log.info("7:around");
return retVal;
}
/*
* spring表达式解析
*
* @ispong
*/
public String spelParseUsername(JoinPoint joinPoint, String expressionStr) {
if (expressionStr.isEmpty()) {
return "";
}
ExpressionParser parser = new SpelExpressionParser();
StandardEvaluationContext context = new StandardEvaluationContext();
String[] params = new LocalVariableTableParameterNameDiscoverer().getParameterNames(((MethodSignature) joinPoint.getSignature()).getMethod());
if (params == null || params.length < 1) {
return "";
}
for (String paramName : params) {
context.setVariable(paramName, joinPoint.getArgs()[paramName.indexOf(paramName)]);
}
return (String) parser.parseExpression(expressionStr).getValue(context);
}
}
请求体
@Data
public class ReqDto {
private String username;
}
注解使用
@Slf4j
@Component
public class DogService {
/*
* 支持动态传参
*
* @ispong
*/
@WatchDog(who = "#reqDto.username")
public void testWatchDog(ReqDto reqDto) {
log.info("4:reqDto {}", reqDto);
}
}
🔗 Links
spring aop
https://ispong.isxcode.com/spring/spring/spring aop/