Spring AOP的基本概念

时间:2022-01-31 06:12:14

        AOP本质        

        AOP(Aspect-Oriented Programming, 面相方面编程),可以说是OOP的补充和完善。OOP

引入封装、继承和多态性等概念来建立一种对象层次结构,用以模拟公共行为的一个集合。当我们

需要为分散的对象引入公共行为的时候,OOP则显得无能为力。也就是说,OOP允许你定义从上

到下的关系,但并不适合定义从左到右的关系。例如日志功能。日志代码往往水平地散布在所有

对象层次中,而与它所散布到的对象的核心功能毫无关系。对于其他类型的代码,如安全性、异常

处理和透明的持续性也是如此。这种散布在各处的无关的代码被称为横切(cross-cutting)代码,

在OOP设计中,它导致了大量代码的重复,而不利于各个模块的重用。

        AOP利用一种称为“横切”的技术,剖解开封装的对象内部,并将那些影响了多个类的公共行为

封装到一个可重用模块,并将其名为“Aspect”,即方面。所谓“方面”,简单地说,就是将那些与业务

,却为业务模块所共同调用的逻辑或责任封装起来,便于减少系统的重复代码,降低模块间的耦合

度,并有利于未来的可操作性和可维护性。AOP代表的是一个横向的关系,如果说“对象”是一个空

心的圆柱体,其中封装的是对象的属性和行为;那么面向方面编程的方法,就仿佛一把利刃,将这些

空心圆柱体剖开,以获得其内部的消息。而剖开的切面,也就是所谓的“方面”了。然后它又以巧夺

天功的妙手将这些剖开的切面复原,不留痕迹。

        使用“横切”技术,AOP把软件系统分为两个部分:核心关注点和横切关注点。业务处理的主要流程

核心关注点,与之关系不大的部分是横切关注点。横切关注点的一个特点是,他们经常在核心关注点

的多处,而各处都基本相似。比如权限认证、日志、事务处理。AOP的作用在于分离系统中的各种关注

点,将核心关注点和横切关注点分离开来。

        AOP的核心思想是“将应用程序中的商业逻辑同对其提供支持的通用服务进行分离。”


        实现AOP的技术主要分为两大类:一是采用动态代理技术,利用截取消息的方式,对该消息进行装

饰,以取代原有对象行为的执行;二是采用静态织入的方式,引入特定的语法创建“方面”,从而使得编译

器可以在编译期间织入有关“方面”的代码。然而殊途同归,实现AP的技术特性却是相同的,分别为:


        1、join point(连接点):是程序执行中的一个精确执行点,例如类中的一个方法。它是一个抽象的概

念,在实现AOP时,并不需要去定义个join point。Spring仅仅支持方法的连接点,即只能在方法调用前,

方法调用后、方法抛出异常时以及方法调用前后这些程序执行点织入增强

        2、point cut(切入点):本质上是一个捕获连接点的结构。在AOP中,可以定义一个point cut,来

捕获相关方法的调用。切入点指出某个类的某些方法是可以织入增强的,但切入点也只定位到具体类的

具体方法,如果要定位到具体的连接点,还要提供方位信息,如方法调用前、调用后等。

        3、advice(增强):是织入到目标类连接点的一段程序代码。在Spring中,增强除了用于描述一段

程序代码外,还拥有执行点的方位。Spring提供的增强接口都是带方位名的。切点指出了对具体类的具体

方法进行增强,advice指出了增强的逻辑和方位,结合两者就可以实施增强逻辑

        4、aspect(切面):point cut和advice结合起来就是aspect,它类似于OOP中定义的一个类,但

它代表的更多是对象间横向的关系

        5、introduction(引介):引介是一种特殊的增强,它可以为类添加一些属性和方法。这样即使一个

业务类原本没有实现某个接口,通过AOP的引介功能,我们可以动态地为该业务类添加接口的实现逻辑,

让业务类成为这个接口的实现类。

        6、Target(目标对象):增强逻辑的织入目标类。可以理解为代理模式中的真实角色,即被代理的

对象。那么代理对象便可以对被代理对象增加处理逻辑。

        7、Weaving(织入):是将增强添加到目标具体类连接点上的过程。

              AOP有三中织入方式:

              1)编译期织入,这要求使用特殊的Java编译器;

              2)类装载器织入,这要求使用特殊的类装载器

              3)动态代理织入,在运行期为目标类添加增强生成子类的方式

              Spring采用动态代理织入,AspectJ采用编译期织入和类装载期织入。

        8、Proxy(代理):一个类被AOP织入增强后,就产生一个结果类,它是融合了原类和增强逻辑的代理

类。代理类可能是和原类拥有相同接口的类,也可能是原类的子类。

        上述的技术特性组成了基本的AOP技术,大多数AOP工具均实现了这些技术。