1.Java平台上的AOP实现机制
1.1 动态代理
限制:被代理的类必须要实现相应的接口。Spring AOP默认采用这种机制。
1.2 动态字节码增强
限制:如果需要扩展的类以及类中的实例方法等都声明为final的话,则无法对其进行子类化的扩展。Spring AOP在无法采用动态代理的时候,会使用CGLIB库的动态字节码增强技术。
2. AOP中的核心概念(以AspectJ为准)
2.1 JoinPoint
在系统运行之前,AOP的功能模块都需要织入到OOP的功能模块中,所以要进行这种织入过程,我们需要知道在系统的哪些执行点上进行织入操作,这些将要在其之上进行织入操作的系统执行点就称之为Joinpoint.
常见的Joinpoint类型:
(1)方法调用(Method Call)但某个方法被调用的时候所处的执行点。
(2)方法调用执行(Method Call execution)某个方法内部开始执行时点。
方法调用是在调用对象上的执行点,而方法执行则是在被调用到的方法逻辑执行的时点,对于同一对象,方法调用要先于方法执行。
(3)构造方法调用(Constructor Call)程序执行的过程中对某个对象调用其构造方法进行初始化的时点。
(4)字段设置(Field Set)
(5)字段获取(Field Get)
(6)异常处理执行(Exception Handler Execution)
(7)类初始化(Class Initialization)
基本上,程序执行过程中你认为必要的执行时点都可以作为Joinpoint。但对于一些位置,捕捉难度不一样。
2.2 Pointcut
Pointcut概念代表的是Jointpoint的表述方式。将横切逻辑织入当前系统的过程中,需要参照Pointcut规定的Jointpoint信息,才可以知道应该往系统的哪些Jointpoint上织入横切逻辑。
Pointcut的表达方式:
(1)直接指定Jointpoint所在方法名称
(2)正则表达式
(3)使用特定的Pointcut表述语言
Pointcut运算
Pointcut与Pointcut之间可以进行逻辑运算,在AspectJ中,可以运用&&以及||。
2.3 Advice
Advice是单一横切关注点逻辑的载体,它代表将会织入到Joinpoint的横切逻辑。
按照Advice在Joinpoint位置执行时机的差异或者完成功能的不同,可以有以下形式:
(1) Before Advice
(2) After Advice
– After Returning Advice
– After Throwing Advice
– After Advice(Finally Advice)
(3) Around Advice
(4) Introduction
不同于上面的Advice是根据在Joinpoint位置执行时机的差异来区分,Introduction是根据它可以完成的功能来区分的。
2.4 Aspect
Aspect是对系统中的横切关注点逻辑进行模块化封装的AOP概念实体,通常情况下,可以包含多个Pointcut以及相关Advice定义。
Spring AOP集成了AspectJ,可以通过使用@AspectJ注解并结合普通的POJO来声明Aspect。
2.5 织入和织入器
织入(Weaving)过程是将以Aspect模块化的横切关注点集成到现有的OOP系统中,而完成织入过程的就是织入器(Weaver)了。
AspectJ有专门的编译器来完成织入操作,即ajc。Spring AOP使用一组类来完成最终的织入操作,ProxyFactory类则是Spring AOP中最通用的织入器。
2.6 目标对象(Target Object)
符合Pointcut所指定的条件,将在织入过程中被织入横切逻辑的对象,称为目标对象。