6.1 Spring概述
自Spring诞生以来,Spring在Java EE企业级应用中应用广泛,致力于简化传统Java EE企业级应用开发过程中烦琐的过程。其实Spring所涵盖的意义远远不止是一个应用框架,下面就来详细解读Spring。
6.1.1 Spring的广义与狭义
Spring有狭义与广义之说。
1.狭义上的Spring——Spring框架
狭义上的Spring特指Spring框架(Spring Framework)。Spring框架是为了解决企业应用开发的复杂性而创建的,它的主要优势之一就是分层架构。分层架构允许使用者选择使用哪一个组件,同时为Java EE应用程序开发提供集成的框架。Spring框架使用基本的POJO来完成以前只可能由EJB完成的事情。Spring框架不仅仅限于服务器端的开发,而且从简单性、可测试性和松耦合的角度来看,Java应用开发均可以从Spring框架中获益。Spring框架的核心是控制反转(IoC)和面向切面(AOP)。简单来说,Spring框架是一个分层的、面向切面与Java应用的一站式轻量级开源框架。
Spring框架的前身是Rod Johnson在Expert One-on-One J2EE Design and Development一书中发表的包含3万行代码的附件。在该书中,他展示了如何在不使用EJB的情况下构建高质量、可扩展的在线座位预留应用程序。为了构建该应用程序,他写了上万行的基础结构代码。这些代码包含许多可重用的Java接口和类,如ApplicationContext和BeanFactory等。由于Java接口是依赖注入的基本构件,因此他将类的根包命名为com.interface21,意味着这个框架是面向21世纪的。根据书中的描述,这些代码已经在一些真实的金融系统中使用。
由于该书影响甚广,当时有几个开发人员(如Juergen Hoeller和Yann Caroff)联系Rod Johnson,希望将com.interface21代码开源。Yann Caroff将这个新框架命名为Spring,其含义为Spring就像一缕春风扫平传统J2EE的寒冬。所以说,Rod Johnson、Juergen Hoeller及Yann Caroff是Spring框架的共同创立者。
2003年2月,Spring 0.9发布,采用了Apache 2.0开源协议。2004年4月,Spring 1.0发布。截至目前,Spring框架已经是第5个主要版本了。有关Spring 5方面的内容可以参阅笔者所著的《Spring 5开发大全》(1)。
2.广义上的Spring——Spring技术栈
广义上的Spring是指以Spring框架为核心的Spring技术栈。这些技术栈涵盖从企业级应用到云计算等各个方面的内容,具体如下:
- Spring Data:Spring框架中的数据访问模块对JDBC及ORM提供了很好的支持。随着NoSQL和大数据的兴起,出现了越来越多的新技术,如非关系型数据库、MapReduce框架。Spring Data正是为了让Spring开发者能更方便地使用这些新技术而诞生的“大”项目——它由一系列小的项目组成,分别为不同的技术提供支持,如Spring Data JPA、Spring Data Hadoop、Spring Data MongoDB、Spring Data Redis等。通过Spring Data,开发者可以用Spring提供的相对一致的方式来访问位于不同类型的数据存储中的数据。在本书后续章节中,也会对Spring Data Redis的使用进行详细的介绍。
- Spring Batch:一款专门针对企业级系统中的日常批处理任务的轻量级框架,能够帮助开发者方便地开发出健壮、高效的批处理应用程序。通过Spring Batch可以轻松构建出轻量级的、健壮的并发处理应用,并支持事务、并发、流程、监控、纵向和横向扩展,提供统一的接口管理和任务管理。Spring Batch对批处理任务进行了一定的抽象,它的架构可以大致分为3层,自上而下分别是业务逻辑层、批处理执行环境层和基础设施层。Spring Batch可以很好地利用Spring框架所带来的各种便利,同时也为开发者提供了相对熟悉的开发体验。有关Spring Batch方面的内容可以参阅笔者所著的《Cloud Native分布式架构原理与实践》(2)。
- Spring Security:前身是Acegi,是较为成熟的子项目之一,是一款可定制化的身份验证和访问控制框架。读者如果对该技术感兴趣,那么可以参阅笔者所著的开源书《Spring Security教程》(3),以了解更多Spring Security方面的内容。在本书后续章节中,会对Spring Security的使用进行详细的介绍。
- Spring Boot:指Spring团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。Spring Boot为Spring平台及第三方库提供了“开箱即用”的设置,这样就可以有条不紊地进行应用的开发。多数Spring Boot应用只需要很少的Spring配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域成为领导者。读者如果对该技术感兴趣,那么可以参阅笔者所著的《Spring Boot企业级应用开发实战》(4)及开源书《Spring Boot教程》(5),以了解更多Spring Boot方面的内容。在本书后续章节中,会对Spring Boot的使用进行详细的介绍。
- Spring Cloud:使用Spring Cloud,开发人员可以“开箱即用”地实现分布式系统中常用的服务。这些服务可以在任何环境下运行,不仅包括分布式环境,还包括开发人员的笔记本电脑、裸机数据中心以及Cloud Foundry等托管平台。Spring Cloud基于Spring Boot来构建服务,并可以轻松地集成第三方类库来增强应用程序的行为。
Spring技术栈还有很多,如果读者感兴趣,可以访问Spring项目页面(https://spring.io/projects)了解更多信息。
3.约定
由于Spring是早期Spring框架的总称,因此有时候Spring这个命名会给读者带来困扰。本书约定Spring框架特指狭义上的Spring,即Spring Framework;而Spring特指广义上的Spring,泛指Spring技术栈。
6.1.2 Spring框架总览
Spring框架是整个Spring技术栈的核心。Spring框架实现了对bean的依赖管理及AOP的编程方式,这些都极大地提升了Java企业级应用开发过程中的编程效率,降低了代码之间的耦合。
Spring框架是很好的一站式构建企业级应用的轻量级的解决方案。
1.模块化的Spring框架
Spring框架是模块化的,允许开发人员自由选择需要使用的部分。例如,可以在任何框架上使用IoC容器,也可以只使用Hibernate集成代码或JDBC抽象层。Spring框架支持声明式事务管理,通过RMI或Web服务远程访问用户的逻辑,并支持多种选择来持久化用户的数据。它提供了一个全功能的Spring Web MVC及Spring WebFlux框架,同时也支持AOP集成到软件中。
2.使用Spring的好处
Spring框架是一个轻量级的Java平台,能够提供完善的基础设施用来支持开发Java应用程序。Spring负责基础设施功能,开发人员可以专注于应用逻辑的开发。Spring可以使用POJO来构建应用程序,并将企业服务非侵入性地应用到POJO。此功能适用于Java SE编程模型和完全或部分Java EE模型。
作为一个Java应用程序的开发者,可以从Spring平台获得以下好处:
- 使本地Java方法可以执行数据库事务,而无须自己处理事务API。
- 使本地Java方法可以执行远程过程,而无须自己处理远程API。
- 使本地Java方法成为HTTP端点,而无须自己处理Servlet API。
- 使本地Java方法可以拥有管理操作,而无须自己处理JMX API。
- 使本地Java方法可以执行消息处理,而无须自己处理JMS API。
6.1.3 Spring框架常用模块
Spring框架基本涵盖了企业级应用开发的各个方面,它由二十多个模块组成。
1.核心容器
核心容器(Core Container)由spring-core、spring-beans、spring-context、spring-context-support和spring-expression(Spring Expression Language)模块组成。
- spring-core和spring-beans模块提供框架的基础部分,包括IoC和Dependency Injection功能。BeanFactory是一个复杂工厂模式的实现,无须编程就能实现单例,并允许开发人员将配置和特定的依赖从实际程序逻辑中解耦。
- spring-context模块建立在spring-core和spring-beans模块提供的功能基础之上,它是一种在框架类型下实现对象存储操作的手段,有一点像JNDI注册。spring-context继承了spring-beans模块的特性,并且增加了对国际化的支持(如用在资源包中)、事件广播、资源加载和创建上下文(如一个Servlet容器)。spring-context模块也支持如EJB、JMX和基础远程访问的Java EE特性。ApplicationContext接口是spring-context模块的主要表现形式。spring-context-support模块提供了对常见第三方库的支持,以便集成到Spring应用上下文,如缓存(EhCache、JCache)、调度(CommonJ、Quartz)等。
- spring-expression模块提供了一种强大的表达式语言,用来在运行时查询和操作对象图。它是作为JSP 2.1规范所指定的统一表达式语言的一种扩展。这种语言支持对属性值、属性参数、方法调用、数组内容存储、收集器和索引、逻辑和算数的操作及命名变量,并且通过名称从Spring的控制反转容器中取回对象。表达式语言模块还支持列表投影、选择和通用列表聚合。
2.AOP及Instrumentation
spring-aop模块提供AOP(面向切面编程)的实现,从而能够实现方法拦截器和切入点完全分离代码。使用源码级别元数据的功能也可以在代码中加入行为信息,在某种程度上类似于.NET属性。
单独的spring-aspects模块提供了集成使用AspectJ。spring-instrument模块提供了类instrumentation的支持和在某些应用程序服务器使用类加载器实现。spring-instrument-tomcat用于Tomcat Instrumentation代理。
3.消息
自Spring Framework 4版本开始提供spring-messaging模块,主要包含从Spring Integration项目中抽象出来的如Message、MessageChannel、MessageHandler及其他用来提供基于消息的基础服务。
该模块还包括一组消息映射方法的注解,类似基于编程模型中的Spring MVC的注解。
4.数据访问/集成
数据访问/集成(Data Access/Integration)层由JDBC、ORM、OXM、JMS和Transaction模块组成。
- spring-jdbc模块提供了一个JDBC抽象层,这样开发人员就能避免进行一些烦琐的JDBC编码和解析数据库供应商特定的错误代码。
- spring-tx模块支持用于实现特殊接口和所有POJO类的编程及声明式事务管理。
- spring-orm模块为流行的对象关系映射API提供集成层,包括JPA和Hibernate。使用spring-orm模块可以将这些O/R映射框架与Spring提供的所有其他功能结合使用,如前面提到的简单的声明式事务管理功能。
- spring-oxm模块提供了一个支持Object/XML映射实现的抽象层,如JAXB、Castor、JiBX和XStream。
- spring-jms模块包含用于生成和使用消息的功能。从Spring Framework 4.1开始,它提供了与spring-messaging的集成。
5.Web
Web层由spring-web、spring-webmvc、spring-websocket和spring-webflux组成。
- spring-web模块提供了基本的面向Web开发的集成功能,如文件上传及用于初始化IoC容器的Servlet监听和Web开发应用程序上下文。它也包含HTTP客户端及Web相关的Spring远程访问的支持。
- spring-webmvc模块(也称Web Servlet模块)包含Spring的MVC功能和REST服务功能。
- spring-websocket模块是基于WebSocket协议通信的程序开发。
- spring-webflux模块是Spring 5新添加的支持响应式编程的Web开发框架。
6.测试
spring-test模块支持通过组合JUnit或TestNG来实现单元测试和集成测试等功能。它不仅提供了Spring ApplicationContexts的持续加载,并能缓存这些上下文,而且提供了可用于孤立测试代码的模拟对象(Mock Objects)。
6.1.4 Spring设计模式
在Spring框架设计中广泛使用了设计模式。Spring使用以下设计模式使企业级应用开发变得简单和可测试。
- Spring使用POJO模式的强大功能来实现企业应用程序的轻量级和最小侵入性的开发。
- Spring使用依赖注入模式(DI模式)实现松耦合,并使系统可以更加面向接口编程。
- Spring使用Decorator和Proxy设计模式进行声明式编程。
- Spring使用Template设计模式消除样板代码。