AOP:Aspect Oriented Programming 面向切面编程
OOP:Object Oriented Programming 面向对象编程

      面向切面编程:基于OOP基础上新的编程思想,OOP面向的主要对象是类,而AOP面向的主要对象是切面,再处理日志,安全管理,事务管理等方面有非常重要的作用。AOP是Spring中重要的核心点,虽然IOC容器没有依赖AOP,但是AOP提供了非常强大的功能,用来对IOC做补充。

      通俗点来说就是在程序运行期间,将某段代码动态切入到指定方法的指定位置进行运行的这种编程方式。

1. AOP的核心概念和术语

在软件业,AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方
式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个
热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑
的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高
了开发的效率。

1.1 AOP与OOP之间的联系和区别

  • 区分
  • AOP、OOP在字面上虽然非常类似,但却是面向不同领域的两种设计思想。OOP(面向对象编程)针对业务处理过程的实体及其属性和行为进行抽象封装,以获得更加清晰高效的逻辑单元划分。
  • 而AOP则是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效果。这两种设计思想在目标上有着本质的差异。
  • 上面的陈述可能过于理论化,举个简单的例子,对于“雇员”这样一个业务实体进行封装,自然是OOP/OOD的任务,我们可以为其建立一个“Employee”类,并将“雇员”相关的属性和行为封装其中。而用AOP设计思想对“雇员”进行封装将无从谈起。
  • 同样,对于“权限检查”这一动作片断进行划分,则是AOP的目标领域。而通过OOD/OOP对一个动作进行封装,则有点不伦不类。
  • 换而言之,OOD/OOP面向名词领域,AOP面向动词领域。
  • 关系
  • 很多人在初次接触 AOP 的时候可能会说,AOP 能做到的,一个定义良好的 OOP 的接口也一样能够做到,我想这个观点是值得商榷的。AOP和定义良好的 OOP 的接口可以说都是用来解决并且实现需求中的横切问题的方法。但是对于 OOP 中的接口来说,它仍然需要我们在相应的模块中去调用该接口中相关的方法,这是 OOP 所无法避免的,并且一旦接口不得不进行修改的时候,所有事情会变得一团糟;AOP 则不会这样,你只需要修改相应的 Aspect,再重新编织(weave)即可。 当然,AOP 也绝对不会代替 OOP。核心的需求仍然会由 OOP 来加以实现,而 AOP 将会和 OOP 整合起来,以此之长,补彼之短。

1.2 相关术语

  1. 切面(Aspect):指关注点模块化,这个关注点可能会横切多个对象

在SpringAOP中,切面可能使用通用类基于模块的方式(Schema
-based approach)或者在普通类中以@Aspect注解来实现

  1. 连接点(JoinPoint):在程序执行过程中某个特定的点,例如某个方法调用的时间点或者处理异常的时间点。在SpringAOP中,连接点总是代表一个方法的执行。
  2. 通知(Advice):在切面的某个特定的连接点执行的动作。通知有多种类型,包括"Before",“After”,“After”,“AfterReturning”,“AfterThrowing”,"Arround"等等,通知的类型将在后面的章节进行详细的讲解
  3. 切点(Pointcut):匹配连接点的断言。通知和切点表达式相关联,并在满足这个切点的连接点上运行。
  4. 引入(Introduction):申明二外的方式或者某个类型的字段
  5. 目标对象(Target Object):被一个或者多个切面所通知的对象。也被通知(Advice)对象。既然SpringAOP是通过运行时代理实现的,那么这个对象永远都是一个被代理(Proxied)的对象
  6. AOP代理(AOP Proxy):AOP框架创建的对象,用来实现切面契约(Aspect Contract)(包括通知方法执行等功能)。在Spring中AOP代理可以是JDK动态代理或者CGLib代理。
  7. 织入(Weaving):把切面连接到其他的应用程序类型或者对象上,创建一个被通知的对象的过程。

1.3 AOP的通知类型

  1. 前置通知(Before):在连接点之前运行但无法阻止执行流程静茹连接点的通知
  2. 后置通知(After):在连接点之后运行,总会执行
  3. 后置返回通知(AfterReturning):在连接点正常完成后执行的通知
  4. 后置异常通知(AfterThrowing):在连接点中出现异常执行的通知
  5. 环绕通知(Arround):将整个方法包起来的通知

2. AOP的应用场景

  1. 日志管理
  2. 权限认证
  3. 安全检查
  4. 事务管理