AOP(Aspect-Oriented Programming)即面向切面编程,是对于OOP的补充。不同于OOP的面向纵向编程,AOP面向的是切面即横向编程,它将纵向的某个流程提取出来,给其添加相应的功能。
简单一句话概括:在运行时,动态地将代码切入到类的指定方法、指定位置上的编程思想。这样做的好处是可以实现在项目开发时,把一些非业务逻辑的功能(比如:日志,权限,异常等等),从执行流程中剥离出来,抽象为一个个切面(aspect),这些切面具有很强的通用性,可以应用在任何一个业务场景里面。如下图所示:

从上图我们可以看出把那些与业务逻辑无关的,却被各个业务模块大量调用的逻辑给封装起来,进而便于减少系统的重复代码量,并且能够降低模块间的耦合度,并有利于未来的扩展和维护,降低了维护成本。最重要的我认为,各个函数本身只关注了核心业务逻辑。
为了更好地理解 AOP,就需要对 AOP 的相关术语有一些了解,这些专业术语主要包含 Joinpoint、Pointcut、Advice、Target、Weaving、Proxy 和 Aspect,它们的含义如下表所示。
| 名称 | 说明 |
|---|---|
| Joinpoint(连接点) | 程序执行的某个特定位置:如类开始初始化前、类初始化后、类某个方法调用前、调用后、方法抛出异常后。 |
| Pointcut(切入点) | 每个程序类都拥有多个连接点,如一个拥有两个方法的类,这两个方法都是连接点,即连接点是程序类中客观存在的事物。 |
| Advice(通知) | 通知是织入到目标类连接点上的一段程序代码,在Spring中,通知除用于描述一段程序代码外,还拥有另一个和连接点相关的信息,这便是执行点的方位。Spring切面可以应用5种类型的通知:Before、After、After-returning、After-throwing和Around |
| Target(目标) | 通知逻辑的织入目标类。 |
| Weaving(植入) | 织入是将通知添加对目标类具体连接点上的过程。 |
| Proxy(代理) | 一个类被AOP织入通知后,就产出了一个结果类,它是融合了原类和通知逻辑的代理类。根据不同的代理方式,代理类既可能是和原类具有相同接口的类,也可能就是原类的子类,所以我们可以采用调用原类相同的方式调用代理类。 |
| Aspect(切面) | 切面由切点和通知组成,它既包括了横切逻辑的定义,也包括了连接点的定义,Spring AOP就是负责实施切面的框架,它将切面所定义的横切逻辑织入到切面所指定的连接点中。 |