[Spring实战系列](16)面向切面编程(AOP)概述

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/50651781 1. 简介在软件中,有些行为对于大多数应用都是通用的。
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/50651781

1. 简介


在软件中,有些行为对于大多数应用都是通用的。日志,安全和事务管理的确很重要,但他们是都是应用对象主动参与的行为呢?如果 让应用对象只关注自己所针对的业务领域问题,而其他方面的问题由其他应用对象来处理 ,这样会不会更好?

在软件开发中,分布于应用中多处的功能被称为 横切关注点。通常,这些横切关注点从 概念上是与应用的业务逻辑相分离的但是往往直接嵌入到应用的业务逻辑中)。 将这些横切关注点与业务逻辑相分离是面向切面编程索要解决的

上图展示了一个被划分为模块的典型应用。 每个模块的核心功能都是为特定业务领域提供服务,但是这些模块都需要类似的辅助功能,例如安全和事务管理。

继承与委托是最常见的实现重用通用功能的面向对象技术。但是,如果在整个应用中使用相同的基类,继承往往会导致一个脆弱的对象体系;而使用委托可能需要委托对象进行复杂的调用。切面提供了取代继承与委托的另一种选择。在使用面向切面编程时, 我们让然在一个地方定义通用功能,但是我们可以通过声明的方式定义这个功能以何种方式在何处应用,而无需修改受影响的类

2. 几个AOP概念

描述AOP功能的术语并不直观,在这共同学习一下。


2.1 通知
在AOP术语中,切面的工作被称为通知。 通知定义了切面是什么以及何时使用。除了描述切面要完成的工作,通知还解决了何时执行这个工作的问题。它该应用与某个方法被调用之前?之后?

类型 说明
Before 在方法被调用之前调用通知。
After 在方法完成之后调用通知,无论方法执行是否成功。
After-returning 在方法成功执行之后调用通知。
After-throwing
在方法抛出异常后调用通知。
Around 通知包裹了被通知的方法,在被通知的方法调用之前和调用之后执行自定义的行为。
2.2 连接点
连接点是在应用执行过程中能够插入切面 的一个点 这个 点可以是调用方法时,抛出异常时,甚至修改一个字段时。切面代码可以利用这些点插入到应用的正常流程之中,并添加新的行为
2.3 切点
一个切面并不需要通知应用的所有连接点。切点有助于缩小切面所通知连接点的范围
2.4 切面
切面是通知和切点的结合。通知和切点共同定义了关于切面的全部内容-----它是什么,在何时和在何处完成其功能。
2.5 引入
引入允许我们向现有的类添加新方法或属性。例如,我们可以创建一个Auditable通知类,该类记录了对象最后一次修改时的状态。我们只需一种方法,setLastModified(Date),和一个实例变量来保存这个状态。然后,这个新方法和实例变量就可以被引入到现有的类中。从而可以在无需修改这些现有的类的情况下,让他们具有新的行为和状态。
2.6 织入
织入是将切面应用到目标对象来创建新的代理对象的过程。切面在指定的连接点被织入到目标对象中。在目标对象的生命周期里有多个点可以进行织入。

3. Spring对AOP的支持


并不是所有的AOP框架都是一样的,尽管有些不同,但是无论如何,创建切点来定义切面织入的连接点是AOP框架的基本功能。

现在主要的AOP框架:
  • AspecJ
  • JBoss AOP
  • Spring AOP

在这里我们主要看Spring对AOP的支持,Spring提供了4种各具特色的AOP支持:
  • 基于代理的经典AOP
  • @AspectJ注解驱动的切面
  • 纯POJO切面
  • 注入式AspectJ切面(适合Spring各版本)
3.1 Spring通知是Java编写的
Spring所创建的通知都是用标准的Java类编写的。这样的话,我们就可以使用与普通Java开发一样的集成开发环境(IDE)来开发切面。而且, 定义通知所应用的切点通常在Spring配置文件里采用XML来编写的。AspectJ与之相反, 虽然AspectJ现在支持基于注解的切面,但是AspectJ最初是以Java语言扩展的方式实现的。这种方式既有优点也有缺点。通过特有的AOP语言,我们可以获得更强大和细粒度的控制,以及更丰富的AOP工具集,但是需要我们学习额外的新工具和语法。
3.2 Spring在运行期通知对象
通过在代理类中包裹切面, Spring在运行期将切面织入到Spring管理的Bean中。代理类封装了目标类,并拦截被通知的方法的调用,再将调用转发给真正的目标Bean。


当拦截到方法调用时,在调用目标Bean方法之前,代理会执行切面逻辑。知道应用需要被代理的Bean时,Spring才创建代理对象。如果使用的是ApplicationContext,在 ApplicationContext从BeanFactory中加载所有的Bean时,Spring创建被代理的对象。因为Spring运行时才创建代理对象,所以我们不需要对特殊的编译器来织入Spring AOP的切面。
3.3 Spring只支持方法连接点
因为Spring是基于动态代理的,所以Spring只支持方法连接点。这与其他一些AOP架构是不同的,例如AspectJ和JBoss,除了方法切点,它们还提供字段和构造器接入点。Spring缺少字段连接点的支持,无法创建更细粒度的通知,例如拦截对象字段的修改,而且Spring也不支持构造器连接点,我们也无法在Bean创建时应用通知。



来源于:《Spring实战》






目录
相关文章
|
1月前
|
XML Java 数据库连接
spring boot 参数的过滤注解与实战
在Spring Boot应用中,对于入参的过滤,通常会涉及到对Web层的数据验证和处理。Spring Boot借助Spring框架提供了强大的验证框架支持,主要基于JSR-303/JSR-380(Bean Validation API)规范,以及Spring自身的@Valid或@Validated注解来实现请求参数的验证。以下是一些常见的使用案例来展示如何对参数进行过滤和验证。
28 1
|
1月前
|
监控 Java 开发者
Spring AOP动态代理
Spring AOP动态代理
43 1
|
27天前
|
设计模式 Java Maven
Spring Aop 底层责任链思路实现-springaopdi-ceng-ze-ren-lian-si-lu-shi-xian
Spring Aop 底层责任链思路实现-springaopdi-ceng-ze-ren-lian-si-lu-shi-xian
31 1
|
25天前
|
安全 Java 数据安全/隐私保护
【深入浅出Spring原理及实战】「EL表达式开发系列」深入解析SpringEL表达式理论详解与实际应用
【深入浅出Spring原理及实战】「EL表达式开发系列」深入解析SpringEL表达式理论详解与实际应用
54 1
|
25天前
|
存储 XML 缓存
【深入浅出Spring原理及实战】「缓存Cache开发系列」带你深入分析Spring所提供的缓存Cache功能的开发实战指南(一)
【深入浅出Spring原理及实战】「缓存Cache开发系列」带你深入分析Spring所提供的缓存Cache功能的开发实战指南
55 0
|
11天前
|
Java 数据库 Spring
切面编程的艺术:Spring动态代理解析与实战
切面编程的艺术:Spring动态代理解析与实战
25 0
切面编程的艺术:Spring动态代理解析与实战
|
20天前
|
XML Java Maven
Spring之Aop的注解使用
Spring之Aop的注解使用
|
26天前
|
Java Spring
Spring 如何实现 AOP
Spring 如何实现 AOP
17 0
|
1月前
|
存储 缓存 安全
Spring Boot从入门到实战
本课程从SpringBoot的最基础的安装、配置开始到SpringBoot的日志管理、Web业务开发、数据存储、数据缓存,安全控制及相关企业级应用,全程案例贯穿,案例每一步的都会讲解实现思路,全程手敲代码实现。让你不仅能够掌SpringBoot的应用,还能了解背后的原理,学习完本课程后,能够让你动手独立完成一个中小型的SpringBoot Web应用开发。
19 1
Spring Boot从入门到实战
|
1月前
|
Java 编译器 程序员
Spring AOP 和 AspectJ 的比较
Spring AOP 和 AspectJ 的比较
36 0

热门文章

最新文章