面向切面编程 Spring

241 阅读3分钟

前言:

本文章取自 《spring实战》,摘取我认为的核心概念。

有一些功能需要用在应用程序的多个地方,然而我们又不希望在每个店都明确调用它。如:日志,安全,事务管理等。比较好的情况是,可以让应用对象只专注于自己的业务领域的问题,而其他的问题交由其他的应用对象来处理。

什么是面向AOP编程

切面能帮助我们模块化横切关注点。简言之,横切关注点可以被描述为影响应用多处的功能。

横切关注点可以被模块化为特殊的类,这些类被称之为切面。

定义AOP术语

描述切面的常用术语有通知(advice),切点(pointcut)和连接点(joinpoint)。

通知(Advice): 在AOP术语中,切面的工作被称为通知。

通知定义了切面是什么以及何时调用。除了描述切面要完成的工作,通知还解决了何时执行这个工作的问题。他应该应用在某个方法被调用之前?之后?之前和之后都调用?还是只在方法抛出异常时调用?

spring切面可以应用五种类型的通知:

1.前置通知(Before):在目标方法被调用之前调用通知功能。

2.后置通知(After):在目标方法完成之后调用通知,此时不会关系方法的输出是什么;

3.返回通知(After-returning):在目标方法成功执行之后调用通知;

4.异常通知(After-throwing):在目标方法抛出异常后调用通知;

5.环绕通知(Around):通知包裹了被通知的方法,在被通知的方法调用之前和调用之后执行自定义的行为。

连接点(Join pont): 连接点是应用程序执行过程中能够插入切面的一个点。这个点可以是调用方法时,抛出异常时,甚至修改一个字段时。切面可以利用这些点插入到应用的正常流程之中,并添加新的行为。

切点(Pointcut): 一个切面并不需要通知应用的所有连接点,切点有助于缩小切面所通知的连接点的范围。如果说,通知定义了切面的“什么”和“何时”的话,那么切点就定义了切面的“何处”。切点的定义会匹配通知所要织入的一个或多个连接点。我们通常使用明确的类和方法名称,或是利用正则表达式定义所匹配的类和方法名称来指定这些切点。

切面(Aspect): 切面是通知和切点的结合。通知和切点共同定义了切面的全部内容————他是什么,在何时和何处完成其功能。

引入(Introduction): 引入允许我们向现有的类添加新方法或属性。

织入(Weaving): 织入是把切面应用到目标对象并创建新的代理对象的过程。切面在指定的连接点被织入到目标 对象中。在目标对象的生命周期里有多个点可以进行织入:

1.编译期:切面在目标类编译时被织入。这种方式需要特殊的编译器。AspectJ的织入编译器就是以这种方式织入切面的。

2.类加载期:切面在目标类被加载到JVM时被织入。这种方式需要特殊的类加载器(ClassLoder),他可以在目标类被引入应用之前增强该目标类的字节码。AspectJ 5 的加载时织入(load-time weaving,LTW)就支持以这种方式织入切面。

3.运行期:切面在应用运行的某个时刻被织入。一般情况下,在织入切面时,AOP容器会为目标对象创建一个代理对象。SpringAOP就是以这种方式织入切面的。