前面我们完成了对Spring IOC容器技术的学习,从本篇文章开始我们将开始学习Spring的另一个核心技术——Spring AOP技术。面向切面编程(Aspect Oriented Programming)简称AOP。
AOP技术的学习我们需要对java反射和代理技术有一定的了解,若你还不太了解java反射和代理技术,可以先对该类技术有简单了解后,继续本篇文章的学习。
一、AOP技术
AOP(Aspect Oriented Programming),面向切面编程。为面向对象编程(OOP)提供了另一种思考应用架构的方式。面向对象编程的关键模块单元是类,而在AOP中关键的模块单元为切面(Aspect)。切面可以实现关注点的模块化,例如跨越多种类型和对象的事务管理。有了AOP技术,我们便可方便的解决分布于系统各个模块中的交叉关注点的问题,如:事务管理、安全检查、缓存和对象池管理等。
二、AOP基本概念
本小节我们介绍一些AOP的一些基本概念和专用术语。
概念 | 描述 |
---|---|
Aspect(切面) | 横跨多个类的关注面的模块化 |
Join point(连接点) | 在程序运行时的某个点:一般指某个方法或异常处理 |
Advice(增强处理) | 切面在特定切点所执行的操作 |
Pointcut(切点) | 匹配连接点的表达式,Advice与Pointcut表达式关联并且Advice将在与Pointcut匹配的所有Joint point |
Introduction | |
Target object | 被一个或多个切面增强处理的对象, |
AOP proxy | AOP代理 |
Weaving(织入) | 将切面与目标对象进行连接。这可以在编译期(AspectJ)、加载期、运行期(Spring AOP) |
Advice类型:
类型 | 描述 |
---|---|
Before advice | 在连接点(Joint point)前执行该增强操作 |
After returning advice | 在连接点正常返回后执行该增强操作 |
After throwing advice | 在连接点抛出异常时执行该增强操作 |
After (finally) advice | 在连接点执行结束后执行该增强操作(无论正常退出还是异常退出) |
Around advice | 包裹连接点的执行操作,该类型可以拦截连接点的执行 |
三、Spring AOP 支持
Spring AOP是由纯java语言实现,因此并不需要特殊的处理,目前Spring AOP仅支持方法运行连接点,如果你需要属性访问和更新连接点,可考虑使用AspectJ,Spring对AspectJ有完善的支持,但这超出了本篇所要学习的重点,有兴趣的读者可自行查阅学习,本文我们主要学习Spring AOP相关知识。
Spring默认使用JDK的动态代理来实现AOP代理,但由于JDK的动态代理只支持对接口的代理,因此如果你需要对类进行代理,Spring同时也提供了CGLIB的代理方式。但一般的商业代码都会要求代码实现一个或多个商业接口,因此一般情况下JDK的动态代理足以使用。总之,无论是JDK动态代理还是CGLIB的代理,Spring良好的封装使得这一切对普通开发者透明。
Spring AOP为我们提供了两种方式来定义切面、切点等关心信息:
- @AspectJ方式:该方式使用注解的方式来定义AOP主要概念,Spring AOP使用和AspectJ 5相同的注解定义。
- 基于XML配置方式
保持一贯风格且使学习便于理解,我们本次Spring AOP依然采用XML的配置方式进行学习。
四、总结
本文我们了解了AOP技术、AOP的基本概念以及Spring的AOP支持,接下来我们将以XML配置的方式讲解Spring AOP的切面(Aspect)、切点(pointcut)等的定义和AOP的使用。