知识点归纳
1. AOP 切入点表达式介绍和使用
2. 实例介绍通知的执行顺序
3. 基于round的的通知执行
4. 基于xml配置的spring aop
4. 基于注解和xml的方式哪个好?
AOP 切入点表达式
Spring aop支持实现AspectJ切断标识符,用于切断表达式,用得最多得是1,2,4.
1. execution 用于匹配方法连接点,用的最多的切点标识符,可以匹配到方法级别,细粒度。基于方法。
@Before(“execution(* cn.allen.service.impl.*.*(..))”)
2. @annotation 匹配那些方法上面存在这个注解的。基于注解。
@Before(“@annotation(jdk.nashorn.internal.runtime.logging.Logger)”)
3. @within只能匹配到类级别,匹配类上面存在这个注解的。
4. this 用来匹配实现了某个接口的类。基于接口。
5. args按参数进行匹配。
表达式合并&& || !,对应于与 或 非
@Before(“execution(* cn.allen.service.impl.*.*(..)) && @annotation(jdk.nashorn.internal.runtime.logging.Logger)")
Spring AOP 通知的执行顺序
执行顺序: 前置 ->后置 ->后置异常 ->后置返回
正常: @Before -> Method -> @After -> @AfterReturning
异常:@Before -> Method -> @After -> @AfterThrowing
对与前置通知,后置通知,后置返回通知,后置异常通知的实例说明。
增加一个知识点,JoinPoint 就是我们前面提到过的链接点,在里面可以得到方法的内部的一些具体信息,如方法名字,方法的参数,具体例子如下
前置通知 @Before, 在被调用的方法之前执行。
后置通知@After,在被调用的方法之后执行
后置返回通知@AfterReturning,在被调用的方法执行即将完成,返回结构之前执行。
后置异常通@AfterThrowing,在被调用的方法发实异常时执行。
@Component
@Aspect
public class LogAspect {
@Before("execution(* com.allen.trainning.spring.aop.dao.impl.*.*(..))")
public void before(JoinPoint point){
System.out.println("@Before --- "+ point.getArgs()[0] + " is the name for a candid