欢迎观看《Spring Framework实战》视频教程

《Spring Framework实战》5:Spring Framework 概述_API

Spring 使创建 Java 企业应用程序变得容易。它为您提供一切 需要在企业环境中采用 Java 语言,并支持 Groovy 和 Kotlin 作为 JVM 上的替代语言,并且可以灵活地创建许多 类型的架构。从 Spring Framework 6.0 开始, Spring 需要 Java 17+。

Spring 支持广泛的应用程序场景。在大型企业中,应用程序 通常存在很长时间,并且必须在升级后的 JDK 和应用程序服务器上运行 cycle 超出了开发人员的控制范围。其他 API 可能作为嵌入了服务器的单个 jar 运行, 可能在云环境中。而其他应用程序可能是独立的应用程序(例如 batch 或集成工作负载)的 Ev Mc.

Spring 是开源的。它有一个庞大而活跃的社区,提供持续的反馈 基于各种实际用例。这帮助 Spring 成功了 在很长一段时间内演变。

1.1. 我们所说的 “Spring” 是什么意思

术语 “Spring” 在不同的上下文中意味着不同的事物。它可以用来指代 Spring Framework 项目本身,这是一切开始的地方。随着时间的推移,其他 Spring 项目已经构建在 Spring 框架之上。大多数情况下,当人们说 “Spring”,他们指的是整个项目系列。本参考文档重点介绍 基础:Spring Framework 本身。

Spring Framework 分为多个模块。应用程序可以选择他们需要的模块。核心是核心容器的模块,包括配置模型和依赖注入机制。除此之外,Spring 框架还提供了基础 支持不同的应用程序架构,包括消息传递、事务数据和 持久性和 Web 的 Web 共享。它还包括基于 Servlet 的 Spring MVC Web 框架,并且在 parallel,Spring WebFlux 反应式 Web 框架。

关于模块的说明:Spring Framework 的 jar 允许部署到模块路径(Java 模块系统)。为了在启用模块的应用程序中使用,Spring 框架 jar 带有定义稳定语言级模块名称的清单条目 (、 等)独立于 jar 工件名称。罐子紧随其后 相同的命名模式,例如 instead 而不是 – 和 . 当然,Spring Framework 的 jar 在 Classpath 上也能正常工作。Automatic-Module-Namespring.corespring.context-.spring-corespring-context

1.2. Spring 和 Spring 框架的历史

Spring 于 2003 年问世,作为对早期 J2EE规范复杂性的回应。 虽然有些人认为 Java EE 及其现代继任者 Jakarta EE 位于 与 Spring 的竞争,它们实际上是互补的。Spring 编程 模型不包含 Jakarta EE 平台规范;相反,它集成了 从传统的 EE 伞中精心挑选的单个规格:

l Servlet API (JSR 340)

l WebSocket API (JSR 356)

l 并发实用程序 (JSR 236)

l JSON 绑定 API (JSR 367))

l Bean 验证 (JSR 303)

l JPA (JSR 338)

l JMS (JSR 914)

l 以及用于事务协调的 JTA/JCA 设置(如有必要)。

Spring Framework 还支持依赖注入 (JSR 330) 和通用注释 (JSR 250) 规范,哪个应用程序 开发人员可以选择使用提供的特定于 Spring 的机制 由 Spring 框架。最初,这些是基于通用包的。javax

从 Spring Framework 6.0 开始,Spring 已升级到 Jakarta EE 9 级别 (例如,Servlet 5.0+、JPA 3.0+),基于名称空间而不是 传统软件包。以 EE 9 为最低版本并且已经支持 EE 10, Spring 已准备好为 Jakarta EE API 的调用。Spring Framework 6.0 与 Tomcat 10.1 完全兼容, Jetty 11 和 Undertow 2.3 作为 Web 服务器,以及 Hibernate ORM 6.1。jakartajavax

随着时间的推移,Java/Jakarta EE 在应用程序开发中的作用发生了变化。在 在 J2EE 和 Spring 的早期,创建应用程序是为了部署到应用程序 服务器。今天,在 Spring Boot 的帮助下,应用程序是在 devops 和 云友好的方式,嵌入了 Servlet 容器,并且很容易更改。截至 Spring Framework 5 是一个 WebFlux 应用程序,甚至不直接使用 Servlet API 并且可以在非 Servlet 容器的服务器(例如 Netty)上运行。

Spring 不断创新和发展。除了 Spring 框架之外,还有其他 项目,例如 Spring Boot、Spring Security、Spring Data、Spring Cloud、Spring Batch、 等等。请务必记住,每个项目都有自己的源代码存储库 Issue Tracker 和 Release Cadence 的 Cadence 进行更新。请参阅 spring.io/projects项目的完整列表。

1.3. 设计理念

当您了解框架时,不仅要知道它做什么,还要知道它做什么 它遵循的原则。以下是 Spring 框架的指导原则:

l 在每个级别提供选择。Spring 允许您尽可能晚地推迟设计决策。 例如,您可以通过配置切换持久性提供程序,而无需更改 您的代码。许多其他基础设施问题以及与 第三方 API。

l 容纳不同的观点。Spring 拥抱灵活性,不固执己见 关于应该如何做事。它支持广泛的应用需求 不同的观点。

l 保持强大的向后兼容性。Spring 的演变得到了精心管理 强制在版本之间进行少量的重大更改。Spring 支持精心挑选的范围 JDK 版本和第三方库,以方便维护应用程序和 依赖于 Spring 的库。

l 关心 API 设计。Spring 团队在制作 API 上投入了大量的思考和时间 它们很直观,并且在许多版本和多年中都适用。

l 为代码质量设定高标准。Spring Framework 非常强调 有意义、最新且准确的 Javadoc。这是极少数可以声称的项目之一 干净的代码结构,包之间没有循环依赖关系。


1.4. 反馈和贡献

对于操作方法问题或诊断或调试问题,我们建议使用 Stack Overflow。单击此处查看可在 Stack Overflow 上使用的建议标签列表。如果你相当确定 Spring Framework 中存在问题或想建议某个功能,请使用 GitHub 问题

如果您有解决方案或建议的修复方法,可以在Github上提交拉取请求。但是,请记住 对于除最琐碎的问题之外的所有问题,我们期望在该问题中提交一个工单 跟踪器,在这里进行讨论并留下记录以供将来参考。

有关更多详细信息,请参阅CONTRIBUTING、 顶层项目页面。

1.5. 开始

如果您刚刚开始使用 Spring,则可能需要开始使用 Spring 框架,通过创建基于 Spring Boot的 应用。Spring Boot 提供了一种快速(且固执己见)的方法来创建一个 生产就绪的基于 Spring 的应用程序。它基于 Spring 框架,偏爱 约定优于配置,旨在让您快速启动并运行 尽可能。

您可以使用start.spring.io生成基本项目或遵循 “入门”指南之一,例如开始构建 RESTful Web 服务。 除了更容易消化之外,这些指南还非常注重任务,而且大多数 基于 Spring Boot。它们还涵盖了 Spring 产品组合中的其他项目,这些项目 在解决特定问题时,您可能需要考虑。