通知簡(jiǎn)介
通知的類(lèi)型共有5個(gè):
@Before:執(zhí)行前
@After:final增強(qiáng),類(lèi)似于final的效果
@AfterThrowing:拋出異常后
@AfterReturning:方法正常返回后
@Around:方法執(zhí)行前后,可以據(jù)此重復(fù)執(zhí)行方法
入門(mén)示例
maven 依賴(lài)
<!-- spring boot aop starter依賴(lài) -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
aop類(lèi)示例
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.stereotype.Component;
/**
* Created by r.x on 2019/10/19.
*/
@Aspect
@Slf4j
@Component
public class DemoAspect {
@Pointcut("execution(public * com.yrx.datasourcemanager.manager.api..*.*(..))")
private void pointcut() {
}
@Before("pointcut()")
private void beforeExeApi(JoinPoint joinPoint) {
log.info("Before");
}
@After("pointcut()")
private void afterExeApi(JoinPoint joinPoint) {
log.info("After");
}
@AfterThrowing("pointcut()")
private void afterThrowingExeApi(JoinPoint joinPoint) {
log.info("AfterThrowing");
}
@AfterReturning("pointcut()")
private void afterReturningExeApi(JoinPoint joinPoint) {
log.info("AfterReturning");
}
@Around("pointcut()")
private Object aroundExeApi(ProceedingJoinPoint joinPoint) {
log.info("Around");
Object result = null;
try {
result = joinPoint.proceed();
} catch (Throwable throwable) {
throwable.printStackTrace();
}
return result;
}
}
注意:必備的注解包括兩個(gè):@Aspect和@Component
切點(diǎn)表達(dá)式
execution切點(diǎn)表達(dá)式,其實(shí)就是方法簽名
execution(public * com.yrx.datasourcemanager.manager.api..*.*(..))
上述切點(diǎn)表達(dá)式解釋?zhuān)?br>
com.yrx.datasourcemanager.manager.api..:表示api包及其子包下的所有類(lèi)
.:表示所有方法名
(..):表示不區(qū)分方法參數(shù),即所有方法