Spring 3.x 整体架构
Spring 4.x 整体架构
上图中,包含了Spring框架的所有模块,接下来分别对体系结构中的模块作用进行简单介绍,具体如下:
1、Core Container (核心容器)
Spring的核心容器是其他模块建立的基础,它主要由Beans模块、Core模块、Context模块、Context-support模块和SpEL(Spring Expression Language,Spring表达式语言)模块组成,具体介绍如下。
- Beans 模块:提供了BeanFactory,是工厂模式的经典实现,Spring将被管理对象称为Bean。
- Core核心 模块:提供了Spring框架的基本组成部分,包括IoC和DI功能。
- Context上下文 模块:建立在Core和Beans模块的基础之上,它是访问定义和配置的任何对象的媒介。其中ApplicationContext接口是上下文模块的焦点。
- Context-support 模块:提供了对第三方库嵌入 Spring 应用的集成支持,比如缓存(EhCache、Guava、JCache)、邮件服务(JavaMail)、任务调度(CommonJ、Quartz)和模板引擎(FreeMarker、JasperReports、速率)。
- SpEL 模块:是Spring 3.0后新增的模块,它提供了Spring Expression Language支持,是运行时查询和操作对象图的强大的表达式语言。
2、Data Access/Integration (数据访问/集成)
数据访问/集成层包括JDBC、ORM、OXM、JMS和Transactions模块,具体介绍如下。
- JDBC 模块:提供了一个JDBC的抽象层,大幅度地减少了在开发过程中对数据库操作的编码。
- ORM 模块:对流行的对象关系映射API,包括JPA、JDO和Hibernate提供了集成层支持。
- OXM 模块:提供了一个支持对象/ XML映射的抽象层实现,如JAXB、Castor、XMLBeans、JiBX和XStream。
- JMS 模块:指 Java 消息传递服务,包含使用和产生信息的特性,自 4.1 版本后支持与Spring-message模块的集成。
- Transactions事务 模块:支持对实现特殊接口以及所有POJO类的编程和声明式的事务管理。
3、Web (B/S系统)
Spring的Web层包括WebSocket、Servlet、Web和Portlet模块,具体介绍如下。
- WebSocket 模块:Spring 4.0以后新增的模块,它提供了WebSocket 和SockJS的实现,以及对STOMP的支持。
- Servlet 模块:也称为Spring-webmvc模块,包含了Spring的模型—视图—控制器(MVC)和REST Web Services实现的Web应用程序。
- Web 模块:提供了基本的Web开发集成特性,例如:多文件上传功能、使用Servlet监听器来初始化IoC容器以及Web应用上下文。
- Portlet 模块:提供了在Portlet环境中使用MVC实现,类似Servlet模块的功能。
4、其他模块
Spring的其他模块还有AOP、Aspects、Instrumentation以及Test模块,具体介绍如下。
- AOP 模块:提供了面向切面编程实现,允许定义方法拦截器和切入点,将代码按照功能进行分离,以降低耦合性。
- Aspects 模块:提供了与AspectJ的集成功能,AspectJ是一个功能强大且成熟的面向切面编程(AOP)框架。
- Instrumentation 模块:提供了类工具的支持和类加载器的实现,可以在特定的应用服务器中使用。
- Messaging 模块:Spring 4.0以后新增的模块,它提供了对消息传递体系结构和协议的支持。
- Test 模块:提供了对单元测试和集成测试的支持。
1、核心容器
1.1 spring-core、spring-beans、spring-beans-groovy
提供了整个框架的基础部分,其中包括 IoC 和控制反转的特性。BeanFactory 是工厂模式复杂化的实现,它解决了程序上单例的需求,并允许你从应用逻辑中分离配置和指定的依赖。
1.2 spring-context
构建在稳定可靠的 Core 和 Beans 的模块上,框架式方式地访问对象的机制类似于 JNDI 注册机制。Context 模块继承了 Beans 模块的特性并增强了国际化(使用的地方如资源配置文件)、事件的传播、资源的加载,和可以透明地创建上下文,比如通过一个 Servlet 容器。Context 模块还支持 Java EE 的特性,如 EJB,JMX 和基础的远程抽象。ApplicationContext 接口是 Context 模块的焦点
1.3 spring-context-support
集成了常见的第三方库到 Spring 应用程序的上下文的支持,缓存(EhCache, Guava, JCache)、邮件 (JavaMail)、调度(CommonJ, Quartz) 和模板引擎(FreeMarker, JasperReports, Velocity)
1.4 spring-expression
提供了强大的运行时对象导航查询和操作的表达式语言,它扩展了 JSP 2.1 规范里的统一表达式语言(EL)。该语言支持设置和获取属性值,属性赋值,方法调用,访问数组元素,集合和索引器,逻辑和算术运算符、命名变量,以及从 Spring 的 IoC 容器根据名字获取对象。它还支持单列的投影和多列的聚合。
2、AOP 和服务器的扩展
2.1 spring-aop
提供了 AOP 联盟兼容的面对切面的编程实现,允许你自定义如方法拦截器和切点,分离应该隔离的业务实现代码。使用源码级的元数据功能,还可以将行为信息合并到你的代码,类似.NET 属性的方式
2.2 spring-aspects
集成了 AspectJ 框架
2.3 spring-instrument
提供了某些应用服务器用到的工具类和类加载器的实现类
2.4 spring-instrument-tomcat
tomcat 的代理类, 如类的加载
3、消息
3.1 spring-messaging
Spring Framework 4 包含了对来自于 Spring-Integration 项目的 Message, MessageChannel, MessageHandler,还有其他基于消息服务作为基础的应用程序的关键性抽象的 spring-messaging 模块。该模块还包含了一套消息映射到方法的注解,就像基于编程模型的 Spring MVC 注解。
4、数据访问和集成
4.1 spring-jdbc
提供了一个 JDBC 抽象层,使得不需要进行繁琐的 JDBC 编码和解析各种数据库产商特定的错误代码。
4.2 spring-tx
为实现指定接口的类和所有你的 POJO 对象提供编程式和声明式的事务管理的支持
4.3 spring-orm
集成了流行的对象关系映射的 APIs,有 JPA,JDO 和 Hibernate。使用 spring-orm 模块,你可以使用所有这些 O/RM 框架与 Spring 相结合而提供的所有其他特性,如简单的声明式的事务管理功能
4.4 spring-oxm
提供了支持对象/XML 的映射实现如 JAXB, Castor, XMLBeans, JiBX 和 XStream 的抽象
4.5 spring-jms
包含了产生和消费消息的功能。Spring Framework 4.1 版本后,它提供了与 spring-messaging 模块的集成
5、Web
5.1 spring-web
提供基本的面向 Web 的集成特性,如多文件的上传功能,使用 Servlet 监听器初始化 IoC 容器,面向 Web 应用程序的上下文。它也包含了一个 Http 客户端和 Spring 远程的网站相关部分
5.2 spring-webmvc
又称 web-servlet 模块。包含了 Spring MVC 和 Rest Web Service 的实现。Spring 的 MVC 框架提供了领域模型代码和 Web 表单之间的完全分离和整合了 Spring 框架的其他所有特性。
5.3 spring-websocket
WebSocket 和 SockJS 的实现,还有 STOMP 协议的支持
5.4 spring-web-portlet
又称 web-portlet 模块。提供 portlet 环境的 MVC 实现和 spring-webmvc 模块的镜像功能。
6、测试
6.1 spring-test
支持和 JUnit 或者 TestNG 一起单元测试和集成测试的 Spring 组件。它提供了一致的 Spring ApplicationContext 的加载与缓存。它还可以模拟对象使得你可以在隔离的环境下测试你的代码。