构建系统

强烈建议您选择支持依赖项管理并且可以使用发布到 Maven Central 存储库的构件的构建系统。 我们建议您选择 Maven 或 Gradle。 可以让 Spring Boot 与其他构建系统(例如 Ant)一起使用,但它们没有得到特别好的支持。spring-doc.cn

依赖关系管理

Spring Boot 的每个版本都提供了它支持的依赖项的精选列表。 实际上,你不需要在构建配置中为这些依赖项中的任何一个提供版本,因为 Spring Boot 会为你管理。 当您升级 Spring Boot 本身时,这些依赖项也会以一致的方式升级。spring-doc.cn

如果需要,您仍然可以指定版本并覆盖 Spring Boot 的建议。

精选列表包含可与 Spring Boot 一起使用的所有 Spring 模块,以及第三方库的精炼列表。 该列表作为标准的物料清单 () 提供,可与 MavenGradle 一起使用。spring-boot-dependenciesspring-doc.cn

Spring Boot 的每个版本都与 Spring Framework 的基本版本相关联。 我们强烈建议您不要指定其版本。

Maven 系列

要了解如何将 Spring Boot 与 Maven 一起使用,请参阅 Spring Boot 的 Maven 插件的文档:spring-doc.cn

Gradle

要了解如何将 Spring Boot 与 Gradle 一起使用,请参阅 Spring Boot 的 Gradle 插件的文档:spring-doc.cn

Ant

可以使用 Apache Ant+Ivy 构建 Spring Boot 项目。 “AntLib” 模块也可用于帮助 Ant 创建可执行的 jar。spring-boot-antlibspring-doc.cn

要声明依赖项,典型文件类似于以下示例:ivy.xmlspring-doc.cn

<ivy-module version="2.0">
	<info organisation="org.springframework.boot" module="spring-boot-sample-ant" />
	<configurations>
		<conf name="compile" description="everything needed to compile this module" />
		<conf name="runtime" extends="compile" description="everything needed to run this module" />
	</configurations>
	<dependencies>
		<dependency org="org.springframework.boot" name="spring-boot-starter"
			rev="${spring-boot.version}" conf="compile" />
	</dependencies>
</ivy-module>

典型情况如以下示例所示:build.xmlspring-doc.cn

<project
	xmlns:ivy="antlib:org.apache.ivy.ant"
	xmlns:spring-boot="antlib:org.springframework.boot.ant"
	name="myapp" default="build">

	<property name="spring-boot.version" value="3.4.0" />

	<target name="resolve" description="--> retrieve dependencies with ivy">
		<ivy:retrieve pattern="lib/[conf]/[artifact]-[type]-[revision].[ext]" />
	</target>

	<target name="classpaths" depends="resolve">
		<path id="compile.classpath">
			<fileset dir="lib/compile" includes="*.jar" />
		</path>
	</target>

	<target name="init" depends="classpaths">
		<mkdir dir="build/classes" />
	</target>

	<target name="compile" depends="init" description="compile">
		<javac srcdir="src/main/java" destdir="build/classes" classpathref="compile.classpath" />
	</target>

	<target name="build" depends="compile">
		<spring-boot:exejar destfile="build/myapp.jar" classes="build/classes">
			<spring-boot:lib>
				<fileset dir="lib/runtime" />
			</spring-boot:lib>
		</spring-boot:exejar>
	</target>
</project>
如果您不想使用该模块,请参见“操作指南”的“从 Ant 构建可执行存档而不使用 spring-boot-antlib”部分。spring-boot-antlib

首先

Starters 是一组方便的依赖项描述符,您可以将其包含在应用程序中。 您可以获得所需的所有 Spring 和相关技术的一站式商店,而无需搜索示例代码和复制粘贴依赖项描述符。 例如,如果您想开始使用 Spring 和 JPA 进行数据库访问,请在项目中包含依赖项。spring-boot-starter-data-jpaspring-doc.cn

Starter 包含许多依赖项,您需要这些依赖项才能快速启动和运行项目,并具有一组一致、受支持的托管传递依赖项。spring-doc.cn

名称中的内容

所有官方Starters都遵循类似的命名模式;,其中 是特定类型的应用程序。 此命名结构旨在在您需要查找Starters时提供帮助。 许多 IDE 中的 Maven 集成允许您按名称搜索依赖项。 例如,安装了适当的 Eclipse 或 Spring Tools 插件后,您可以在 POM 编辑器中按 “spring-boot-starter” 并键入 “spring-boot-starter” 以获取完整列表。spring-boot-starter-**ctrl-spacespring-doc.cn

创建您自己的 Starter 部分所述,第三方 starters 不应以 ,因为它是为官方 Spring Boot 工件保留的。 相反,第三方Starters通常以项目名称开头。 例如,名为 的第三方初学者项目通常命名为 。spring-bootthirdpartyprojectthirdpartyproject-spring-boot-starterspring-doc.cn

Spring Boot 在该组下提供了以下应用程序Starters:org.springframework.bootspring-doc.cn

表 1.Spring Boot 应用程序Starters
名字 描述

spring-boot-starterspring-doc.cn

核心Starters,包括自动配置支持、日志记录和 YAMLspring-doc.cn

spring-boot-starter-activemqspring-doc.cn

使用 Apache ActiveMQ 的 Starter for JMS 消息传递spring-doc.cn

spring-boot-starter-amqpspring-doc.cn

使用 Spring AMQP 和 Rabbit MQ 的入门spring-doc.cn

spring-boot-starter-aopspring-doc.cn

使用 Spring AOP 和 AspectJ 进行面向方面编程的入门spring-doc.cn

spring-boot-starter-artemisspring-doc.cn

使用 Apache Artemis 的 Starter for JMS 消息传递spring-doc.cn

spring-boot-starter-batchspring-doc.cn

使用 Spring Batch 的 Starterspring-doc.cn

spring-boot-starter-cachespring-doc.cn

使用 Spring Framework 的缓存支持的 Starterspring-doc.cn

spring-boot-starter-data-cassandraspring-doc.cn

使用 Cassandra 分布式数据库和 Spring Data Cassandra 的入门spring-doc.cn

spring-boot-starter-data-cassandra-reactivespring-doc.cn

使用 Cassandra 分布式数据库和 Spring Data Cassandra Reactive 的入门spring-doc.cn

spring-boot-starter-data-couchbasespring-doc.cn

使用 Couchbase 面向文档的数据库和 Spring Data Couchbase 的入门spring-doc.cn

spring-boot-starter-data-couchbase-reactivespring-doc.cn

使用 Couchbase 面向文档的数据库和 Spring Data Couchbase Reactive 的入门spring-doc.cn

spring-boot-starter-data-elasticsearchspring-doc.cn

使用 Elasticsearch 搜索和分析引擎和 Spring Data Elasticsearch 的入门版spring-doc.cn

spring-boot-starter-data-jdbcspring-doc.cn

使用 Spring Data JDBC 的初学者spring-doc.cn

spring-boot-starter-data-jpaspring-doc.cn

将 Spring Data JPA 与 Hibernate 结合使用的入门spring-doc.cn

spring-boot-starter-data-ldapspring-doc.cn

使用 Spring Data LDAP 的入门spring-doc.cn

spring-boot-starter-data-mongodbspring-doc.cn

使用 MongoDB 面向文档的数据库和 Spring Data MongoDB 的入门spring-doc.cn

spring-boot-starter-data-mongodb-reactivespring-doc.cn

使用 MongoDB 面向文档的数据库和 Spring Data MongoDB Reactive 的入门spring-doc.cn

spring-boot-starter-data-neo4jspring-doc.cn

使用 Neo4j 图形数据库和 Spring Data Neo4j 的入门spring-doc.cn

spring-boot-starter-data-r2dbcspring-doc.cn

使用 Spring Data R2DBC 的Startersspring-doc.cn

spring-boot-starter-data-redisspring-doc.cn

将 Redis 键值数据存储与 Spring Data Redis 和 Lettuce 客户端结合使用的入门spring-doc.cn

spring-boot-starter-data-redis-reactivespring-doc.cn

将 Redis 键值数据存储与 Spring Data Redis 反应式和 Lettuce 客户端一起使用的入门spring-doc.cn

spring-boot-starter-data-restspring-doc.cn

使用 Spring Data REST 和 Spring MVC 通过 REST 公开 Spring Data 存储库的入门spring-doc.cn

spring-boot-starter-freemarkerspring-doc.cn

使用 FreeMarker 视图构建 MVC Web 应用程序的入门spring-doc.cn

spring-boot-starter-graphqlspring-doc.cn

使用 Spring GraphQL 构建 GraphQL 应用程序的入门spring-doc.cn

spring-boot-starter-groovy-templatesspring-doc.cn

使用 Groovy Templates 视图构建 MVC Web 应用程序的 Starterspring-doc.cn

spring-boot-starter-hateoasspring-doc.cn

使用 Spring MVC 和 Spring HATEOAS 构建基于超媒体的 RESTful Web 应用程序的入门spring-doc.cn

spring-boot-starter-integrationspring-doc.cn

使用 Spring 集成的 Starterspring-doc.cn

spring-boot-starter-jdbcspring-doc.cn

将 JDBC 与 HikariCP 连接池一起使用的入门spring-doc.cn

spring-boot-starter-jerseyspring-doc.cn

使用 JAX-RS 和 Jersey 构建 RESTful Web 应用程序的入门工具。spring-boot-starter-web 的替代方案spring-doc.cn

spring-boot-starter-jooqspring-doc.cn

使用 jOOQ 通过 JDBC 访问 SQL 数据库的入门工具。spring-boot-starter-data-jpaspring-boot-starter-jdbc 的替代方案spring-doc.cn

spring-boot-starter-jsonspring-doc.cn

用于读取和写入 json 的 Starterspring-doc.cn

spring-boot-starter-mailspring-doc.cn

使用 Java Mail 和 Spring Framework 的电子邮件发送支持的入门spring-doc.cn

spring-boot-starter-mustachespring-doc.cn

使用 Mustache 视图构建 Web 应用程序的入门spring-doc.cn

spring-boot-starter-oauth2-authorization-serverspring-doc.cn

使用 Spring Authorization Server 功能的入门spring-doc.cn

spring-boot-starter-oauth2-clientspring-doc.cn

使用 Spring Security 的 OAuth2/OpenID Connect 客户端功能的入门spring-doc.cn

spring-boot-starter-oauth2-resource-serverspring-doc.cn

使用 Spring Security 的 OAuth2 资源服务器功能的入门spring-doc.cn

spring-boot-starter-pulsarspring-doc.cn

使用 Spring for Apache Pulsar 的入门spring-doc.cn

spring-boot-starter-pulsar-reactivespring-doc.cn

使用 Spring for Apache Pulsar Reactive 的入门spring-doc.cn

spring-boot-starter-quartzspring-doc.cn

使用 Quartz 调度程序的入门spring-doc.cn

spring-boot-starter-rsocketspring-doc.cn

用于构建 RSocket 客户端和服务器的 Starterspring-doc.cn

spring-boot-starter-securityspring-doc.cn

使用 Spring Security 的 Starterspring-doc.cn

spring-boot-starter-testspring-doc.cn

用于使用 JUnit Jupiter、Hamcrest 和 Mockito 等库测试 Spring Boot 应用程序的 Starterspring-doc.cn

spring-boot-starter-thymeleafspring-doc.cn

使用 Thymeleaf 视图构建 MVC Web 应用程序的入门spring-doc.cn

spring-boot-starter-validationspring-doc.cn

将 Java Bean 验证与 Hibernate 验证器结合使用的入门spring-doc.cn

spring-boot-starter-webspring-doc.cn

使用 Spring MVC 构建 Web(包括 RESTful)应用程序的入门工具。使用 Tomcat 作为默认嵌入式容器spring-doc.cn

spring-boot-starter-web-servicesspring-doc.cn

使用 Spring Web 服务的入门spring-doc.cn

spring-boot-starter-webfluxspring-doc.cn

使用 Spring Framework 的反应式 Web 支持构建 WebFlux 应用程序的入门spring-doc.cn

spring-boot-starter-websocketspring-doc.cn

使用 Spring Framework 的 MVC WebSocket 支持构建 WebSocket 应用程序的入门工具spring-doc.cn

除了应用程序Starters之外,以下Starters还可用于添加生产就绪功能:spring-doc.cn

表 2.Spring Boot 生产Starters
名字 描述

spring-boot-starter-actuatorspring-doc.cn

使用 Spring Boot 的 Actuator 的 Starter,它提供生产就绪功能来帮助您监控和管理应用程序spring-doc.cn

最后,Spring Boot 还包括以下Starters,如果你想排除或交换特定的技术方面,可以使用这些Starters:spring-doc.cn

表 3.Spring Boot 技术Starters
名字 描述

spring-boot-starter-jettyspring-doc.cn

使用 Jetty 作为嵌入式 servlet 容器的入门工具。spring-boot-starter-tomcat 的替代方案spring-doc.cn

spring-boot-starter-log4j2spring-doc.cn

使用 Log4j2 进行日志记录的入门。spring-boot-starter-logging 的替代方案spring-doc.cn

spring-boot-starter-loggingspring-doc.cn

使用 Logback 进行日志记录的Starters。默认日志记录Startersspring-doc.cn

spring-boot-starter-reactor-nettyspring-doc.cn

使用 Reactor Netty 作为嵌入式反应式 HTTP 服务器的Starters。spring-doc.cn

spring-boot-starter-tomcatspring-doc.cn

使用 Tomcat 作为嵌入式 servlet 容器的入门工具。spring-boot-starter-web 使用的默认 servlet 容器Startersspring-doc.cn

spring-boot-starter-undertowspring-doc.cn

使用 Undertow 作为嵌入式 servlet 容器的入门工具。spring-boot-starter-tomcat 的替代方案spring-doc.cn

要了解如何交换技术方面,请参阅交换 Web 服务器日志记录系统的操作文档。spring-doc.cn

有关其他社区贡献的启动程序的列表,请参阅 GitHub 上模块中的 README 文件spring-boot-starters