1 AspectJ:Java 社区里最完整最流行的 AOP 框架.
2 在 Spring2.0 以上版本中, 可以使用基于 AspectJ 注解或基于 XML 配置的 AOP
3. 在 Spring 中启用 AspectJ 注解支持
•要在 Spring 应用中使用 AspectJ 注解, 必须在 classpath 下包含 AspectJ 类库:
aopalliance.jar、aspectj.weaver.jar 和 spring-aspects.jar
•将 aop Schema 添加到 <beans> 根元素中.
•要在 Spring IOC 容器中启用 AspectJ 注解支持, 只要在 Bean 配置文件中定义一个空的 XML 元素
<aop:aspectj-autoproxy>
<!-- 让 AspectJ注解起作用:自动为匹配的类生成代理对象-->
<aop:aspectj-autoproxy></aop:aspectj-autoproxy>
•当 Spring IOC 容器侦测到 Bean 配置文件中的 <aop:aspectj-autoproxy> 元素时,
会自动为与 AspectJ 切面匹配的 Bean 创建代理.
4.基于注解的方式。•在 AspectJ 注解中, 切面只是一个带有 @Aspect 注解的 Java 类.
4.1 配置文件中加入 <aop:aspectj-autoproxy> (作用使AspectJ注解起作用)
4.2 把横切关注点的代码抽象到切面类中
•切面也是IOC容器的bean,使用注解加入IOC容器(@Component)
•切面换需要加入@Aspect注解,证明他是切面
•在类中声明各种通知。AspectJ 支持 5 种类型的通知注解:
–@Before: 前置通知, 在方法执行之前执行
–@After: 后置通知, 在方法执行之后执行
–@AfterRunning: 返回通知, 在方法返回结果之后执行
–@AfterThrowing: 异常通知, 在方法抛出异常之后
–@Around: 环绕通知, 围绕着方法执行
•可以在通知方法中声明一个类型为 JoinPoint 的参数. 然后就能访问链接细节. 如方法名称和参数值.
•切入点表达式:@Before("execution(int com.lishenhuan.aop.impl.ArithmeticCalculator.*(int, int))")
–execution * com.atguigu.spring.ArithmeticCalculator.*(..): 匹配 ArithmeticCalculator 中声明的所有方法,
第一个 * 代表任意修饰符及任意返回值. 第二个 * 代表任意方法. .. 匹配任意数量的参数.
若目标类与接口与该切面在同一个包中, 可以省略包名.
–execution public * ArithmeticCalculator.*(..): 匹配 ArithmeticCalculator 接口的所有公有方法.
–execution public double ArithmeticCalculator.*(..): 匹配 ArithmeticCalculator 中返回 double 类型数值的方法
–execution public double ArithmeticCalculator.*(double, ..): 匹配第一个参数为 double 类型的方法,
.. 匹配任意数量任意类型的参数
–execution public double ArithmeticCalculator.*(double, double): 匹配参数类型为 double, double 类型的方法.
•合并切入点表达式:在 AspectJ 中, 切入点表达式可以通过操作符 &&, ||, ! 结合起来.
/*
* 把该类声明成一个切面,
* 1.放入IOC容器 @Component
* 2.声明为一个切面 @Aspect
*/
@Aspect
@Component
public class Log {
//前置通知:在目标方法之前执行
@Before("execution(int com.lishenhuan.aop.impl.ArithmeticCalculator.*(int, int))")
public void before(JoinPoint joinPoint) {
//获取目标方法名称
String mathodName = joinPoint.getSignature().getName();
//获取目标方法参数
List<Object> args = Arrays.asList(joinPoint.getArgs());
System.out.println("The method " + mathodName + " begin with " +args);
}
}