`

Spring AOP 剖析(3)

阅读更多

AOP  涉及到的几个基本概念

 

1. Joinpoint                  ---     可以在系统中织入横切逻辑的位置   


2. Pointcut                   ---     用来描述系统中所有需要织入横切逻辑的 Joinpoint 的集合


3. Advice                      ---     将要被织入到 Joinpoint 中的横切逻辑


4. Aspect                      ---     对 以上三种概念 进行模块化的封装,相当于 OOP 中的 Class


5. Weaving And Weaver   ---   具体完成横切逻辑到系统的最终织入,这个相当重要啊,没有这个,其他的都是扯淡了


6. Target Object            ---   满足 Pointcut 的条件,将要被织入横切逻辑的对象

 

 


1. Jointpoint

 

系统运行之前,AOP 的功能模块都需要织入到 OOP 的功能模块中。要进行这种织入过程,就需要知道在系统的哪些

 

执行点上进行织入操作,这些将要在其上进行织入操作的系统执行点就是 Joinpoint。

 

 

常见的 Joinpoint 类型:

 

a.  Method Call  (方法调用) -- 当某个方法被调用的时候所处的程序执行点。


b.  Method Call Execution (方法执行) -- 某个方法内部执行开始时点。

 

Method Call 是在调用对象上的执行点,而 Method Call Execution 则是在被调用到的方法逻辑执行的时点,对于同一对象,方法调用要先于方法执行。

 

如图:

 


 

c.  Constructor Call (构造方法调用) -- 程序执行过程中对某个对象调用其构造方法进行初始化的时点。

 

d.  Constructor Call Execution (构造方法执行) -- 构造方法执行和构造方法调用之间的关系类似于方法执行和方法调用之间的关系,指的是某个对象构造方法内部执行的开始时点。

 

e.  Field Set (字段设置) -- 对象的某个属性通过 setter 方法被设置或者直接被设置的时点。 该 Joinpoint 的本质是对象的属性被设置,而通过 setter 方法设置还是直接设置触发的时点是相同的。

 

f.   Exception Handler Execution (异常处理执行) -- 该类型的 Joinpoint 对应程序执行过程中,在某些类型异常抛出后,对应的异常处理逻辑执行的时点。

 

g.  Class Initialization (类初始化) -- 该 Joinpoint 指的是类中某些静态类型或者静态块的初始化时点。

 

 

 

2.  Pointcut

 

Joinpoint 只是指明: 可以在系统中织入横切逻辑的一些时点而已。 所以光有 Joinpoint 是远远不够的。 

 

接下来需要知道, 我需要织入横切逻辑的所有的具体位置到底是在哪里呢,即到底在哪些 Joinpoint 上面呢?

 

那么,Pointcut 就是做这个工作的, 她用来说明系统中所有需要织入横切逻辑的位置具体是哪些 Joinpoint

 

 

关于 Pointcut 是如何描述 系统中所有需要织入的横切逻辑的具体 Joinpoint  的呢?

 

a.  直接指定 Joinpoint 所在的方法名称。

 

      这种形式的 Pointcut 表述方式比较简单,而且功能单一,通常只限于支持方法级别的 Joinpoint 的 AOP 框架,或者

 

只是方法执行类型的 Joinpoint。 而且,即使是只针对方法级别的 Joinpoint, 因为系统中需要织入横切逻辑的方法可能

 

很多,一个一个地指定则过于不便,所以这种方式通常只限于 Joinpoint 较少且较为简单的情况。


b.  正则表达式。

 

      这是比较普遍的 Pointcut 表达方式,可以充分利用正则表达式的强大功能,来归纳表述需要符合某种条件的多组

 

Joinpoint。 几乎现在大部分的 Java 平台的 AOP 产品都支持这种形式的 Pointcut 表达形式。 Spring 的 AOP 框架就


可以采用正则表达式的方式来描述 Pointcut 。

 

c.  使用特定的 Pointcut 表述语言。

 

      这是一种最为强大的表达 Pointcut 的方式,灵活性也很好,但具体实现起来可能过于复杂,需要设置该表述语言的

 

语法,实现相应的解释器等许多工作。 AspectJ 使用这种方式来指定 Pointcut,它提供了一种类似于正则表达式的针对

 

Pointcut 的表述语言,在表达 Pointcut 方面支持比较完善。 Spring 从2.0版之后,借助 AspectJ 的 Pointcut


表述语言解释器,现在也支持使用 AspectJ 的 Pointcut 表述语言来指定 Pointcut 。

 

 

 

 

3.  Advice

 

OK,现在有了  可以植入横切逻辑的时点(Joinpoint), 也有了 需要织入横切逻辑的所有的时点的集合(Pointcut),

 

但是,还不知道需要织入的 横切逻辑 到底是什么呢? 于是乎 Advice 就出现了。

 

Advice 代表将会被织入到 Joinpoint 的横切逻辑。

 

 

按照 Advice 在 Joinpoint 位置执行时机的差异或者完成功能的不同,Advice可以分为多种具体形式。

 

a.  Before Advice

 

Before Advice 是在 Joinpoint 指定位置之前执行的 Advice 类型。通常,它不会中断程序执行流程,但如果必要,

 

可以通过在 Before Advice 中抛出异常的方式来中断当前流程。 如果当前 Before Advice 将被织入到方法执行类型的

 

Joinpoint, 那么这个 Before Advice 就会先于方法执行而执行。

 

b.  After Advice

 

After Advice 是在 Joinpoint 指定位置之后执行的 Advice 类型,但是该类型的 Advice 还可以细分为以下三种:


1.  After returning Advice    只有当 Joinpoint 处执行流程正常完成后,After returning Advice 才会执行。

 

比如:方法执行正常返回而没有抛出异常。

 

2.  After throwing Advice     又称为  Throws Advice , 只有在当前 Joinpoint 执行过程中抛出异常的情况下,才会

 

执行。 比如:方法执行类型的 Joinpoint 抛出某异常而没有正常返回。

 

3.  After Advice   或许叫 After (Finally) Advice 更为准确, 该类型 Advice 不管 Joinpoint 处执行流程是正常

 

还是抛出异常都会执行, 就好像 Java 中的 finally 块一样。

 


c.  Around Advice 

 

Around Advice 是对附加其上的 Joinpoint 进行“包裹”, 可以在 Joinpoint 之前和之后都指定相应的逻辑,甚至于中断

 

或者忽略 Joinpoint 处原来程序流程的执行。

 

好吧,找不到图了,自己画一个, 大概就这样子吧。

 


既然 Around Advice 可以在 Joinpoint 之前和之后都能执行相应的逻辑,那么,它自然可以完成 Before Advice 和

 

After Advice 的功能。 不过,通常情况下,还是应该根据场景选用更为具体的 Advice 类型。

 

Around Advice 应用场景非常广泛,J2EE 中 Filter 功能就是一种 Around Advice 。 使用它,我们可以完成

 

“资源初始化”,“安全检查”之类的 系统横切关注点了。

 

d.  Introduction 

 

Introduction 不是根据横切逻辑在 Joinpoint 处的执行时机来区分的,而是根据它可以完成的功能而区别于

 

其他 Advice 类型。  Introduction 可以为原有的对象添加新的特性或者行为。

 

关于这种 Advice , 我还不是很了解, 就先放下,以后弄明白再补充。 O(∩_∩)O~

 

 


4.  Aspect

 

Aspect 是对系统中的横切关注点逻辑进行模块化封装的 AOP 概念实体。 通常,Aspect 可以包含多个 Pointcut 以及

 

相关的 Advice 定义。 比如,以 AspectJ 形式定义的 Aspect :

 



  Spring AOP 最初没有 “完全” 确切的实体对应真正的 Aspect 的概念。 在 2.0 发布后, 因为集成了 AspectJ ,所以

 

可以通过使用 @AspectJ 的注解并结合普通的 POJO 来声明 Aspect 。

 

 

 

5.  Weaving And Weaver

 

Weaving(织入)过程就是连接 AOP 与 OOP 的那座桥, 只有经过织入过程后,以 Aspect 模块化的横切逻辑才会集成

 

到 OOP 的现存系统中。而完成织入过程的那个 “人”  就称为 Weaver (织入器)。

 

 

AspectJ 有 专门的编译器 来完成织入操作, 即 ajc ,所以 ajc 就是 AspectJ 完成织入的 织入器;

 

JBoss AOP 采用 自定义的类加载器 来完成最终织入,那么这个 自定义的类加载器 就是它的织入器;


Spring AOP 使用 一组类 来完成最终的织入操作, ProxyFactory类 则是 Spring AOP 最通用的织入器;

 

总之, Java平台 AOP 实现的织入器形式各样,唯一形同的就是它们的职责,即 完成横切关注点逻辑到系统的最终织入

 

 

 

6.  Target Object

 

符合 Pointcut 所指定的条件,将在织入过程中被织入横切逻辑的对象,称为 Target Object (目标对象)

 

 

 

AOP 各种概念组合图

 


  • 大小: 57.2 KB
  • 大小: 52 KB
  • 大小: 14.6 KB
  • 大小: 50 KB
  • 大小: 147.7 KB
分享到:
评论

相关推荐

    死磕Spring之AOP篇 - Spring AOP两种代理对象的拦截处理(csdn)————程序.pdf

    Spring AOP 是一种面向切面编程的技术,它允许我们在不修改源代码的情况下,对应用程序的特定部分(如方法调用)进行增强。在 Spring 中,AOP 的实现主要依赖于代理模式,有两种代理方式:JDK 动态代理和 CGLIB 动态...

    AOP流程源码分析-SpringAOP中定义的类图

    AOP流程源码分析-SpringAOP中定义的类图AOP流程源码分析-SpringAOP中定义的类图AOP流程源码分析-SpringAOP中定义的类图AOP流程源码分析-SpringAOP中定义的类图AOP流程源码分析-SpringAOP中定义的类图AOP流程源码分析...

    Spring AOP实现机制

    **Spring AOP 实现机制详解** Spring AOP(面向切面编程)是Spring框架的核心特性之一,它允许程序员在不修改源代码的情况下,通过“切面”来插入额外的业务逻辑,如日志、事务管理等。AOP的引入极大地提高了代码的...

    五、Spring源码分析——Spring Aop

    《Spring AOP 源码分析》 在深入探讨Spring AOP之前,我们先要理解AOP(面向切面编程)的基本概念。AOP是一种编程范式,它将关注点分离,使得我们可以将横切关注点(如日志、事务管理、安全检查等)与业务逻辑解耦...

    spring aop 学习笔记

    3. **注解驱动的AOP** - `@Aspect`:标记一个类为切面。 - `@Before`:前置通知,方法在目标方法之前执行。 - `@After`:后置通知,无论目标方法是否正常执行,都在其之后执行。 - `@AfterReturning`:返回后...

    Spring AOP框架实现的结构分析

    在本文中,我们将从实现的角度来认识 SpringAOP 框架,从外部接口、内部实现、组成部分、执行过程四个方面来介绍 Spring AOP 框架的结构分析。 最后,本文的目标是从实现的角度来认识 SpringAOP 框架,观察的角度是...

    spring-aop-jar

    3. 性能监控:统计方法的执行时间,用于性能分析。 4. 安全控制:在方法调用前检查权限。 总结起来,"spring-aop-jar"涉及了Spring框架中的面向切面编程模块,包括Spring AOP和AspectJ的集成。通过理解和熟练使用...

    Spring AOP简单demo

    **Spring AOP 简介** Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的一个重要模块,它扩展了传统的面向对象编程,允许开发者定义“横切关注点”(cross-cutting concerns),如日志、事务...

    spring AOP的运用

    在本文中,我们将深入探讨Spring AOP的运用,并结合源码分析其工作原理。 首先,了解AOP的基本概念: 1. 切面(Aspect):切面是关注点的模块化,这些关注点通常是跨越多个对象的横切关注点,例如事务管理、日志...

    spring aop 经典例子(原创)

    Spring AOP,全称Aspect-Oriented Programming,是Spring框架中的一个重要组成部分,它引入了面向切面编程的概念,使得开发者可以将关注点分离,更好地实现业务逻辑与系统服务的解耦。在这个经典例子中,我们将深入...

    JavaEE Spring AOP使用

    通过分析这个测试案例,你可以了解如何在实际项目中实现AOP。例如,它可能包含了一个带有切面逻辑的切面类,使用了`@Before`注解的方法会在目标方法执行前运行,而使用`@After`注解的方法则会在目标方法执行后运行。...

    Spring aop 性能监控器

    本篇文章将深入探讨如何使用Spring AOP实现性能监控器,并通过源码分析来理解其工作原理。 首先,我们要了解AOP的核心概念——切面(Aspect)、通知(Advice)、连接点(Join Point)、切入点(Pointcut)和织入...

    Spring Aop使用实例

    **Spring AOP 使用实例** Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的一个重要组成部分,它提供了一种在不修改原有代码的情况下,通过代理方式添加额外功能的技术。这种技术使得我们...

    spring aop 附带测试实例

    在提供的压缩包文件"springAOP"中,可能包含了以下内容: - **切面类(Aspect Class)**:包含切点和通知的Java类,可能使用了`@Aspect`注解。 - **目标类(Target Class)**:被AOP代理的对象,通常包含业务逻辑。...

    springAOP核心组件分析.pdf

    Spring AOP(面向切面编程)是Spring框架的一个重要组成部分,它允许开发者将横切关注点与业务逻辑分离,实现业务逻辑的模块化。AOP核心组件包括几个关键概念,如切面(Aspect)、通知(Advice)、连接点(Joinpoint...

    Spring AOP需要jar包.rar

    3. spring-core.jar:Spring的核心库,提供了基本的IoC(Inversion of Control,控制反转)功能和核心工具类。 4. spring-context.jar:扩展了spring-beans,提供了上下文支持,包括事件发布、国际化、资源加载等...

    Spring AOP实现 项目源码 Myeclipse 直接导入可用

    3. `Spring配置文件`:定义了AOP的相关配置,如启用AOP、定义切面和通知等。 4. `测试类`:用于验证AOP是否正常工作,调用Service类中的方法并观察日志或其他切面效果。 通过研究这个项目源码,你可以了解如何在...

    spring源码--AOP流程--笔记.docx

    Spring AOP 源码分析笔记 Spring AOP(Aspect-Oriented Programming)是一种编程范式,它允许开发者 modularize cross-cutting concerns,即将横切关注点模块化。AOP 使得开发者可以将一些公共的功能模块化,以便在...

    Spring AOP的底层实现技术

    Spring AOP(面向切面编程)是Spring框架的重要组成部分,它提供了一种模块化和声明式的方式来处理系统中的交叉关注点,如日志、事务管理、性能监控等。AOP的核心概念包括切面(Aspect)、通知(Advice)、连接点...

Global site tag (gtag.js) - Google Analytics