Spring 的整体架构

Spring 的整体架构

学如弓弩,才如箭簇

开局一张图,内容全靠编。

Spring 框架图

上图是 Spring 的整体框架图,主要分为了几大块: Core Container、Data Access/Integration、Web、AOP 和 Test。下面我们一一讲解这几个模块,至于其它的Aspects、Instrumentation和Messaging,本文就不多做赘述。

Core Container

Core Container 的意思是核心容器,它包括了BeansCoreContextSpEL(Spring Expression Language) 四个模块。

Core 和 Beans 模块是框架的基础部分,提供 IoC (控制反转)和依赖注入特性。 这里的基础概念是 BeanFactory ,它提供对 Factory 模式的经典实现来消除对程序性单例模式的需要,并真正地允许你从程序逻辑中分离出依赖关系和配置。

  • Core 模块包括了 Spring 框架的基本的核心工具类, Spring的其它组件都要用到这个包里面的类,Core 模块是其他纽件的基本核心 。
  • Beans 模块是所有应用都妥用到的,它包含访问配置文件、创建和管理 bean 以及进行 Inversion of Control / Dependency Injection ( IoC/DI )操作相关的所有类 。
  • Context 模块构建于 Core 和 Beans 模块基础之上,提供了一种类似于JNDI 注册器的框架式的对象访问方法。 Context 模块继承了 Beans 的特性,为 Spring 核心提供了大量 扩展,添加了对国际化(例如资源绑定)、事件传播、资源加载和对 Context 的透明创建的支持。 Context 模块同时也支持 J2EE 的一些特性, 例如 EJB 、JMX和基础的远程处理 。 ApplicationContext 接口是 Context 模块的关键 。
  • Expression Language 模块提供了强大的表达式语言,用于在运行时查询和操纵对象。它是 JSP 2.1 规范中定义的 unifed expression language 的扩展。 该语言支持设置/获取属性的值,属性的分配,方法的调用,访问数组上下文( accessiong the context of arrays )、 容器和索引器、逻辑和算术运算符、命名变量以及从 Spring 的 IoC 容器中根据名称检索对象。 它也支持 list 投影、选择和一般的 list 聚合。

Data Access / Integration

Data Access 模块包括了: 事务、DAO、 JDBC、ORM、 XML机制。

  • JDBC 模块提供了一个 JDBC 抽象层,他可以消除冗长的 JDBC 编码和解析数据库厂商特有的错误代码,这个模块包括了 Spring 对 JDBC 数据访问进行封装的所有类。
  • ORM 模块为流行的对象-关系映射,如JPA、JDO、Hibernate、iBatis等,提供了一个交互层,利用 ORM 封装包,可以混合使用所有 Spring 提供的特性进行 O/R 映射。
  • OXM 模块提供了一个对 Object / XML 映射实现的抽象层,Object / XML 映射实现包括JAXB、Castor、XMLBeans、JiBX 和 XStream。
  • JMS (Java Messaging Service)模块主要包括了一些制造和消费消息的特性
  • Transaction 模块支持编程和声明性的事务管理,这些事务类必须实现特定的接口,并且对所有的 POJO 都适用 。

Web

Web 上下文模块建立在应用程序上下文模块之上,为基于 Web 的应用程序提供了上下文。 所以, Spring 框架支持与 Jakarta Struts 的集成。 Web 模块还简化了处理大部分请求以及将请求参数绑定到域对象的工作。 Web 层包含了 Web 、 Web-Servlet、 Web-Struts 和 Web-Porlet 模块,具体说明如下。

  • Web 模块:提供了基础的面向 Web 的集成特性。 例如,多文件上传、使用 servlet listeners 初始化 IoC 容器以及一个面向 Web 的应用上下文。 它还包含 Spring 远程支持中 Web 的相关部分。
  • Web- Servlet 模块 web.servlet.jar :该模块包含 Spring 的 model-view-controller ( MVC) 实现。 Spring 的 MVC 框架使得模型范围内的代码和 web forms 之间能够清楚地分离开 来,并与 Spring 框架的其他特性集成在一起。
  • Web-Struts 模块:该模块提供了对 Struts 的支持, 使得类在 Spring 应用中能够与一个 典型的 Struts Web 层集成在一起。 注意,该支持在 Spring 3.0 中已被弃用 。
  • Web-Porlet 模块:提供了用于 Portlet 环境和 Web-Servlet 模块的 MVC 的实现。

AOP

AOP 模块提供了一个符合 AOP 联盟标准的面向切面编程的实现,它让你可以定义例如方法拦截器和切点,从而将逻辑代码分开,降低它们之间的调合性。 利用 source-level 的元数据功能,还可以将各种行为信息合并到你的代码中,这有像.Net 技术中的 attribute 概念。

通过配置管理特性, SpringAOP 模块直接将面向切面的编程功能集成到了 Spring 框架中, 所以可以很容易地使 Spring 框架管理的任何对象支持 AOP。 Spring AOP 模块为基于 Spring 的 应用程序中的对象提供了事务管理服务。 通过使用 SpringAOP ,不用依赖 EJB 组件,就可以将声明性事务管理集成到应用程序中 。

  • Aspects 模块提供了对 AspectJ 的集成支持。
  • Instrumentation 模块提供了 class instrumentation 支持和 classloader 实现, 使得可以在特定的应用服务器上使用 。

本篇文章摘自《Spring 源码深度解析(第二版)》

Copyright: 采用 知识共享署名4.0 国际许可协议进行许可

Links: https://baozi.fun/archives/spring-structure

Buy me a cup of coffee ☕.