2105 2017-12-01 2024-07-31

无论基于什么样的原因,放弃阅读源码始终不是一个明智的选择,因为你失去了一个跟大师学习的机会。

这个过程虽然有一点艰辛、枯燥、头晕,但大牛们都可以做到,你也可以!向大牛进发!

一、概述

Spring是2003年兴起的一个轻量级的Java开源框架,由Rod Johnson在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。Spring是为了解决企业应用开发的复杂性而创建的,它使用基本的JavaBean来完成以前只可能由EJB完成的事情。

然而,Spring的用途不仅限于服务器端的开发。从简单性可测试性松耦合的角度而言,任何Java应用都可以从Spring中收益。

Spring框架是一个分层框架,它包含一系列的功能要素,并被分为大约20个模块,如图

Spring整体架构图

二、Core Container

Core Container(核心容器)包含有Core、Beans、Context、Expression Language模块

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

1、Core模块

Core模块主要包含Spring框架基本的核心工具类,Spring的其他组件都要使用到这个包里面的类,Core模块是其他组件的基本核心。当然你也可以在自己的应用系统中使用这些工具类。

2、Beans模块

Beans模块是所有应用都要用到的,它包含访问配置文件、创建和管理bean以及进行Inversion of Control / Dependency Injection(IoC/DI)操作相关的所有类。

3、Context模块

Context模块构建于Core和Beans模块基础之上,提供了一种类似于JNDI(Java Naming and Directory Interface)注册器的框架式的对象访问方法。Context模块继承了Beans的特性,为Spring核心提供了大量扩展,添加了对国际化(例如资源绑定)、事件传播、资源加载和对Context的透明创建的支持。Context模块同时也支持J2EE的一些特性,例如EJB、JMX和基础的远程处理。ApplicationContext接口是Context模块的关键。

4、Expression Language

Expression Language模块提供了一个强大的表达式语言用于在运行时查询和操纵对象。它是JSP2.1规范中定义的unifed expression language的一个扩展。该语言支持设置/获取属性的值,属性的分配,方法的调用,访问数组上下文(accession the context of arrays)、容器和索引器、逻辑和算术运算符、命名变量以及从Spring的IoC容器中根据名称检索对象。它也支持list投影、选择和一般的list聚合。

三、Data Access/Integration

Data Access/Integration层包含有JDBC、ORM、OXM、JMS和Transaction模块。

1、JDBC模块

JDBC模块提供了一个JDBC抽象层,它可以消除冗长的JDBC编码和解析数据库厂商特有的错误代码。这个模块包含了Spring对JDBC数据访问进行封装的所有类。

2、ORM模块

ORM模块为流行的对象-关系映射API,如JPA、JDO、Hibernate、iBatis等,提供了一个交互层。利用ORM封装包,可以混合使用所有Spring提供的特性进行O/R映射。如前边提到的简单声明性事务管理。

Spring框架插入了若干个ORM框架,从而提供了ORM的对象关系工具,其中包括JDO、Hibernate和iBatisSQL Map。所有这些都遵从Spring的通用事务和DAO异常层次结构。

3、OXM模块

OXM模块提供了一个对Object/XML映射实现的抽象类,Object/XML映射实现包括JAXB、Castor、XMLBeans、JiBX和XStream。

4、JMS模块

JMS(Java Message Service)模块主要包含了一些制造和消费消息的特性。

5、Transaction模块

Transaction模块支持编程和声明性的事务管理,这些事务类必须实现特定的接口,并且对所有的POJO都适用。

四、Web

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

1、Web模块

Web模块提供了基础的面向Web的集成特性。例如,多文件上传、使用servlet listeners初始化IoC容器以及一个面向Web的应用上下文。它还包含Spring远程支持中Web的相关部分。

2、Web-Servlet模块

Web-Servlet模块(web.servlet.jar)包含Spring的model-view-controller(MVC)实现。Spring的MVC框架使得模型范围内的代码和web forms之间能够清楚地分离开来,并与Spring框架的其他特性集成在一起。

3、Web-Struts模块

该模块提供了对Struts的支持,使得类在Spring应用中能够与一个典型的Struts Web层集成在一起。注意,该支持在Spring3.0中是deprecated的。

4、Web-Porlet模块

提供了用于Porlet环境和Web-Servlet模块的MVC的实现。

五、AOP

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

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

1、AspectJ模块

AspectJ模块提供了对AspectJ的集成支持。

2、Instrumentation模块

该模块提供了class instrumentation支持和classloader实现,使得可以在特定的应用服务器上使用。

六、Test

Test模块支持使用JUnit和TestNG对Spring组件进行测试。

七、Why use it

Spring最根本的使命就是:简化Java开发。这是一个郑重的承诺,许多框架都声称在某些方面做了简化,但Spring的目标是致力于全方位的简化Java开发。这势必会引出更多的解释,Spring是如何简化Java开发的?

为了简化Java开发的复杂性,Spring采用了以下4种关键策略:

  • 基于POJO的轻量级和最小侵入性编程。
  • 通过依赖注入和面向接口实现松耦合。
  • 基于切面和惯例进行声明式编程。
  • 通过切面和模板减少样板式代码。

针对最近比较火的Spring Boot,对于与Spring的区别,可以用一句概括:Spring Boot只是Spring本身的扩展,使开发,测试和部署更加方便。具体可以表现在以下几个方面

  • 创建独立的Spring应用(内嵌了如Tomcat类web容器)
  • 约定优于配置,尽可能地自动配置Spring应用
  • 提供各种Starters、各种注解帮助构建Spring应用
  • 全方位的简化,使Spring更加易于上手、易于使用

八、总结

本文作为Spring源码开篇,做了Spring源码整体架构的介绍,暂未涉及到过多的细节。后续规划具体如下

  1. 后续将会围绕某一个模块深入展开讨论,例如IoC、AOP、Web等
  2. 后续将会结合实际的面试题做下讨论分析,均为个人真实遇到的面试场景,均为国内一二线公司(数量10+)
  3. 最后会从零写个Spring Boot,代码开源(针对Web场景,理论上可以完全替代Spring Boot,之前写过一版,但还不够完善)
总访问次数: 37次, 一般般帅 创建于 2017-12-01, 最后更新于 2024-07-31

进大厂! 欢迎关注微信公众号,第一时间掌握最新动态!