深入剖析Spring架构与设计原理(二)
来源:互联网 发布:阿里云备案客服 编辑:程序博客网 时间:2024/05/19 01:14
深入剖析Spring架构与设计原理(二)
1. AOP
上一个章节说了IOC,这个章节我们来说说Spring另一个非常重要的特性-AOP.AOP联盟定义的AOP体系结构把与AOP相关的概念大致分为了由高到低、从使用到实现的三个层次。关于这个体系结构,个人的理解是这样的,从上往下,最高层是语言和开发环境,在这个环境中可以看到几个重要的概念:base可以视为待增强对象,或者说目标对象;aspect指切面,通常包含对于base的增强应用;configuration可以看成是一种编织或者说配置,通过在AOP体系中提供这个configuration配置环境,可以把base和aspect结合起来,从而完成切面对目标对象的编织实现。
对Spring平台或者说生态系统来说,AOP是Spring框架的核心功能模块之一。AOP与IOC容器的结合使用, 为应用开发或者Spring自身功能的扩展都提供了许多便利。SpringAOP的实现和其他特性的实现一样,非常丰富,除了可以使用Spring本身提供的AOP实现之外,还封装了业界优秀的AOP解决方案AspectJ来让应用使用。在这里,主要对Spring自身的AOP实现原理做一些解析;在这个AOP实现中,Spring充分利用了IOC容器Proxy代理对象以及AOP拦截器的功能特性,通过这些对AOP基本功能的封装机制,为用户提供了AOP的实现框架。所以,要了解这些AOP的基本实现,需要我们对Java的Proxy机制有一些基本了解。
2.AOP实现的基本思路
AOP实现中,可以看到三个主要的步骤,一个是代理对象的生成,然后是拦截器的作用,然后是Aspect编织的实现。AOP框架的丰富,很大程度体现在这三个具体实现中,所具有的丰富的技术选择,以及如何实现与IOC容器的无缝结合。毕竟这也是一个非常核心的模块,需要满足不同的应用需求带来的解决方案需求。
在Spring AOP的实现原理中,我们主要举ProxyFactoryBean的实现作为例子和实现的基本线索进行分析;很大一个原因,是因为ProxyFactoryBean是在Spring IoC环境中,创建AOP应用的最底层方法,从中,可以看到一条实现AOP的基本线索。在ProxyFactoryBean中,它的AOP实现需要依赖JDK或者CGLIB提供的Proxy特性。从FactoryBean中获取对象,是从getObject()方法作为入口完成的。然后为proxy代理对象配置advisor链,这个配置是在initializeAdvisorChain方法中完成的;然后就为生成AOP代理对象做好了准备,生成代理对象如下所示:
上面我们看到了在Spring中通过ProxyFactoryBean实现AOP功能的第一步,得到AopProxy代理对象的基本过程,下面我们看看AopProxy代理对象的拦截机制是怎样发挥作用,是怎样实现AOP功能的。我们知道,对代理对象的生成,有CGLIB和JDK两种生成方式,在CGLIB中,对拦截器设计是通过在Cglib2AopProxy的AopProxy代理对象生成的时候,在回调DynamicAdvisedInterceptor对象中实现的,这个回调的实现在intercept方法中完成。对于AOP是怎样完成对目标对象的增强的,这些实现是封装在AOP拦截器链中,由一个个具体的拦截器来完成的。具体拦截器的运行是在以下的代码实现中完成的,这些调用在ReflectiveMethodInvocation中。代码详细见2.java
在调用拦截器的时候,我们接下去就可以看到对advice的通知的调用。而经过一系列的注册,适配的过程以后,拦截器在拦截的时候,会调用到预置好的一个通知适配器,设置通知拦截器,这是一系列Spring设计好为通知服务的类的一个,是最终完成通知拦截和实现的地方,非常的关键。比如,对MethodBeforeAdviceInterceptor的实现是这样的:
在代码中,可以看到,就是这里,会调用advice的before方法!这样就成功的完成了before通知的编织!
因为Spring AOP本身并不打算成为一个一统天下的AOP框架,秉持Spring的一贯设计理念,设想中的Spring设计目标应该是,致力于AOP框架与IOC容器的紧密集成,通过集成AOP技术为JavaEE应用开发中遇到的普遍问题提供解决方案,从而为AOP用户使用AOP技术提供最大的便利,从这个角度上为Java EE的应用开发人员服务。在没有使用第三方AOP解决方案的时候,Spring通过虚拟机的Proxy特性和CGLIB实现了AOP的基本功能,我想,如果有了Spring AOP实现原理的知识背景,再加上我们对源代码实现的认真解读,可以为我们了解其他AOP框架与IOC容器的集成原理,也打下了很好的基础,并真正了解一个AOP框架是在怎样实现的。
这还真是就是我们喜欢开源软件一个原因,有了源代码,软件就没有什么神秘的面纱了!本立而道生,多读源代码吧,或者找一本从源代码出发讲解软件实现的书来看看,就像以前我们学习操作系统,学习TCP/IP那样!一定会有长进的。
- 深入剖析Spring架构与设计原理(二)
- 深入剖析Spring架构与设计原理(一)
- 深入解析Spring架构与设计原理(二)AOP原理
- Spring技术内幕——深入解析Spring架构与设计原理(二)AOP
- Spring技术内幕——深入解析Spring架构与设计原理(二)AOP
- Spring技术内幕——深入解析Spring架构与设计原理(二)AOP
- Spring技术内幕——深入解析Spring架构与设计原理(二)AOP
- 《深入解析Spring架构与设计原理》阅读笔记1
- 深入解析Spring架构与设计原理-AOP
- SPRING技术内幕:深入解析SPRING架构与设计原理(第2版)-笔记(二)IOC注入
- 深入探索spring技术内幕(二): 剖析spring管理Bean的原理与配置
- 深入探索spring技术内幕(二): 剖析spring管理Bean的原理与配置
- Spring技术内幕——深入解析Spring架构与设计原理(六)Spring ACEGI
- 《深入解析Spring架构与设计原理》阅读笔记(一)----IOC容器的设计与实现
- 深入解析Spring架构与设计原理(一)IOC实现原理
- 推荐一本好书《spring 技术内幕---深入解析spring架构与设计原理》
- 推荐一本好书《spring 技术内幕---深入解析spring架构与设计原理》
- 书讯:《Spring技术内幕——深入解析Spring架构与设计原理》
- 【STL源码剖析读书笔记】【第4章】序列式容器之list和slist
- Session的生命周期
- HDU4762Cut the Cake(概率)
- 嵌入式的学习规划
- BFS--- HDU 1240 Asteroids! 广度优先搜索
- 深入剖析Spring架构与设计原理(二)
- cocos2dx + android点击返回键两下退出游戏实现
- PLSQL没有“登录为“选项 ,并且监听程序当前无法识别连接描述符中请求的服务
- C#获取当前文件的路经
- MAVEN打包所遇问题集合
- <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>意义
- Azure云平台学习之路(二)——SQL Database
- HDU 1527 (POJ 1067) 取石子游戏 Wythoff Game
- [学习笔记]Xcode的简单使用