八、Spring中的AOP
8.1 什么是AOP?
AOP的全程是Aspect-Oriented Programming,即面向切面编程(也称面向方面编程)。它是面向对象编程(OOP)的一种补充,目前已经成为一种比较成熟的编程方式。
问题:在传统的业务处理代码中,通常都会进行事务处理、日志记录等操作。虽然使用OOP可以通过组合或者继承的方式来达到代码的重用,但如果要实现某个功能(比如日志记录等),同样的代码仍然会分散到各个方法中。如果想要关闭某个功能,或者对其进行修改,就必须要修改所有的相关方法,显然,这不但增加了开发人员的工作量,而且会提高代码的出错率。
解决:为了解决这一问题,AOP思想随之产生。AOP采取横向抽取机制,将分散在各个方法中的重复代码提取出来,然后在程序编译或运行时,再将这些提取出来的代码应用到需要执行的地方。这种采用横向抽取机制的方式,采用传统的OOP思想显然是无法办到的,因为OOP只能实现父子关系的纵向的重用。虽然AOP是一种新的编程思想,但却不是OOP的替代品,它只是OOP的延伸和补充。
小贴士:
在这几个切面中,分别实现不同的事务处理,这样可以使开发人员专心于核心业务,而不用过多地关注其他业务逻辑的实现,这不但提高了开发效率,而且增强了代码的可维护性。
目前最流行的AOP框架有两个,分别为Spring AOP和AspectJ:
- Spring AOP:使用纯Java实现,不需要专门的编译过程和类加载器,在运行期间通过代理方式向目标类织入增强的代码。
- AspectJ:是一个基于Java语言的AOP框架,AspectJ扩展了Java语言,提供了一个专门的编译器,在编译时提供横向代码的织入。
8.2 AOP的目标
让我们可以“专心做事”。
8.3 AOP的原理
- 将复杂的需求分解出不同方面,将散布在系统中的公共功能集中解决;
- 采用代理机制组装起来运行,在不改变原程序的基础上对代码段进行增强处理,增加新的功能。
注意:
- AOP只是一种思想,它与具体的实现技术无关,任何一种符合AOP思想的技术实现,都可以看做是AOP的实现。通过java的动态代理机制,就可以很容易实现AOP的思想,实际上Spring的AOP也是建立在Java的代理机制上。
- AOP实际上是由目标类的代理类实现的。AOP代理其实就是由AOP框架动态生成的一个对象,该对象可作为目标对象使用。AOP代理包含了目标对象的全部方法,但是AOP代理中的方法与目标对象的方法存在差异,AOP方法在特定切入点添加了增强处理,并回调了目标对象的方法。
8.4 AOP相关术语
- Aspect(切面):在实际应用中,切面通常是指封装的用于横向插入系统功能(如事务、日志等)的类,该类要被Spring容器识别为切面,需要在配置文件中通过bean元素指定。
- Joinpoint(连接点):在程序执行过程中的某个阶段点,它实际上是对象的一个操作,在Spring AOP中,连接点就是指方法的调用。
- Pointcut(切入点):是指切面与程序流程的交叉点,即那些需要处理的连接点。通常在程序中,切入点指的是类或者方法名,如某个通知要应用到所有以add开头的方法中,那么所有满足这一规则的方法都是切入点。
- Advice(通知/增强处理):AOP框架在特定的切入点执行的增强处理,即在定义好的切入点处所要执行的程序代码。可以将其理解为切面类中的方法,它是切面的具体实现。
- Target Object(目标对象):是指所有被通知的对象,也称为被增强对象。如果AOP框架采用的是懂爱的AOP实现,那么该对象就是一个被代理对象。
- Proxy(代理):将通知应用到目标对象之后,被动态创建的对象。
- Weaving(织入):将切面代码插入到目标对象,从而生产代理对象的过程。