此版本仍在开发中,尚未视为稳定版。如需最新稳定版本,请使用 Spring Boot 4.0.4spring-doc.cadn.net.cn

构建系统

强烈建议您选择一个支持依赖管理、并且能够使用发布到 Maven Central 仓库的构件的构建系统。 我们推荐您选择 Maven 或 Gradle。 虽然也可以让 Spring Boot 与其他构建系统(例如 Ant)一起工作,但它们并未得到特别良好的支持。spring-doc.cadn.net.cn

依赖管理

每个版本的Spring Boot都会提供一个它所支持的依赖项列表。 在实际操作中,您无需在其构建配置中为这些任何依赖项指定版本号,因为Spring Boot会为您管理这一点。 当您升级Spring Boot本身时,这些依赖项也会以一致的方式进行更新。spring-doc.cadn.net.cn

您仍然可以指定版本并覆盖 Spring Boot 的推荐设置,如果需要的话。

该精选列表包含了所有可以与 Spring Boot 一起使用的 Spring 模块,以及经过精炼的第三方库列表。 该列表以标准物料清单(spring-boot-dependencies)的形式提供,并且可以与 MavenGradle 一起使用。spring-doc.cadn.net.cn

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

Maven

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

Gradle

使用 Spring Boot 与 Gradle,请参阅 Spring Boot 的 Gradle 插件文档:spring-doc.cadn.net.cn

Ant

可以使用Apache Ant+Ivy构建一个Spring Boot项目。 Ant的“AntLib”模块也可以用来帮助Ant创建可执行jar文件。spring-doc.cadn.net.cn

要声明依赖项,一个典型的ivy.xml文件看起来像下面这个例子:spring-doc.cadn.net.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.xml如下所示:
spring-doc.cadn.net.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.5.13-SNAPSHOT" />

	<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>
如果不希望使用spring-boot-antlib模块,请参阅《如何从Ant构建可执行存档而不使用spring-boot-antlib》部分中的“如何-to指南”。

Starters

Starters 是一组方便的依赖描述符,你可以将其包含在你的应用中。 你无需通过查找示例代码和复制粘贴大量的依赖描述符就能获得所需的全部 Spring 及相关技术。 例如,如果你想使用 Spring 和 JPA 进行数据库访问,请将 spring-boot-starter-data-jpa 依赖添加到你的项目中。spring-doc.cadn.net.cn

starters 包含了启动项目所需的大多数依赖项,可以快速并一致地运行项目,并且具有受支持的管理传递依赖集。spring-doc.cadn.net.cn

什么是命名

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

根据在xref page部分的解释,第三方Starters不应以../features/developing-auto-configuration.html#features.developing-auto-configuration.custom-starter开头,因为该名称保留给官方Spring Boot组件使用。 相反,第三方Starters通常以项目的名称开始。例如,一个名为spring-boot的第三方Starters项目,通常会被命名为thirdpartyprojectspring-doc.cadn.net.cn

以下应用Starters由 Spring Boot 在 org.springframework.boot 组下提供:spring-doc.cadn.net.cn

表 1. Spring Boot 应用Starters
姓名 <description> </description>

spring-boot-starterspring-doc.cadn.net.cn

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

spring-boot-starter-activemqspring-doc.cadn.net.cn

使用 Apache ActiveMQ 的 JMS 消息Startersspring-doc.cadn.net.cn

spring-boot-starter-amqpspring-doc.cadn.net.cn

使用Spring AMQP和RabbitMQ的Startersspring-doc.cadn.net.cn

spring-boot-starter-aopspring-doc.cadn.net.cn

面向切面编程的启动项,使用Spring AOP和AspectJspring-doc.cadn.net.cn

spring-boot-starter-artemisspring-doc.cadn.net.cn

使用 Apache Artemis 的 JMS 消息Startersspring-doc.cadn.net.cn

spring-boot-starter-batchspring-doc.cadn.net.cn

使用Spring批处理的起步指南spring-doc.cadn.net.cn

spring-boot-starter-cachespring-doc.cadn.net.cn

使用 Spring 框架缓存支持的Startersspring-doc.cadn.net.cn

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

使用 Cassandra 分布式数据库和 Spring Data Cassandra 的Startersspring-doc.cadn.net.cn

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

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

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

使用Couchbase文档导向数据库和Spring Data Couchbase的Startersspring-doc.cadn.net.cn

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

使用Couchbase文档导向数据库和Spring Data Couchbase Reactive 的起步指南spring-doc.cadn.net.cn

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

使用Elasticsearch搜索和分析引擎以及Spring Data Elasticsearch的入门引导spring-doc.cadn.net.cn

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

Spring Data JDBC 使用starterspring-doc.cadn.net.cn

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

使用 Spring Data JPA 与 Hibernate 的Startersspring-doc.cadn.net.cn

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

Spring Data LDAP 使用starterspring-doc.cadn.net.cn

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

使用 MongoDB 文档型数据库和 Spring Data MongoDB 的起步指南spring-doc.cadn.net.cn

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

使用 MongoDB 文档数据库和 Spring Data MongoDB 响应式starterspring-doc.cadn.net.cn

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

使用 Neo4j 图数据库和 Spring Data Neo4j 的入门指南spring-doc.cadn.net.cn

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

使用 Spring Data R2DBC 的 Starterspring-doc.cadn.net.cn

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

使用 Spring Data Redis 和 Lettuce 客户端与 Redis 键值存储的数据存储器 starterspring-doc.cadn.net.cn

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

使用 Spring Data Redis 响应式库和 Lettuce 客户端与 Redis 键值数据存储结合的Startersspring-doc.cadn.net.cn

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

使用 Spring Data REST 和 Spring MVC 暴露 Spring Data 仓库的 REST 起点spring-doc.cadn.net.cn

spring-boot-starter-freemarkerspring-doc.cadn.net.cn

使用FreeMarker 视图构建MVC网络应用程序的入门包spring-doc.cadn.net.cn

spring-boot-starter-graphqlspring-doc.cadn.net.cn

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

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

使用 Groovy Templates 视图构建 MVC Web 应用程序的入门包spring-doc.cadn.net.cn

spring-boot-starter-hateoasspring-doc.cadn.net.cn

基于 Spring MVC 和 Spring HATEOAS 构建超媒体驱动的RESTful Web 应用程序的 Starterspring-doc.cadn.net.cn

spring-boot-starter-integrationspring-doc.cadn.net.cn

使用Spring Integration 的入门指南spring-doc.cadn.net.cn

spring-boot-starter-jdbcspring-doc.cadn.net.cn

使用HikariCP 连接池的JDBC Starterspring-doc.cadn.net.cn

spring-boot-starter-jerseyspring-doc.cadn.net.cn

用于构建基于 JAX-RS 和 Jersey 的 RESTful Web 应用程序的Starters。它是 spring-boot-starter-web 的替代方案。spring-doc.cadn.net.cn

spring-boot-starter-jooqspring-doc.cadn.net.cn

用于通过 JDBC 访问 SQL 数据库的 jOOQ Starters。spring-boot-starter-data-jpaspring-boot-starter-jdbc 的替代方案。spring-doc.cadn.net.cn

spring-boot-starter-jsonspring-doc.cadn.net.cn

JSON读写入门spring-doc.cadn.net.cn

spring-boot-starter-mailspring-doc.cadn.net.cn

使用Java Mail和Spring框架发送电子邮件的Startersspring-doc.cadn.net.cn

spring-boot-starter-mustachespring-doc.cadn.net.cn

使用Mustache视图构建Web应用程序的起步spring-doc.cadn.net.cn

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

使用 Spring Authorization Server 功能的入门指南spring-doc.cadn.net.cn

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

使用 Spring Security性模块的 OAuth2 和 OpenID Connect 客户端功能的Startersspring-doc.cadn.net.cn

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

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

spring-boot-starter-pulsarspring-doc.cadn.net.cn

使用 Spring 连接 Apache Pulsar 的入门指南spring-doc.cadn.net.cn

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

使用Spring进行Apache Pulsar 响应式编程的Startersspring-doc.cadn.net.cn

spring-boot-starter-quartzspring-doc.cadn.net.cn

使用Quartz调度器的启动项spring-doc.cadn.net.cn

spring-boot-starter-rsocketspring-doc.cadn.net.cn

RSocket 客户端和服务器构建器spring-doc.cadn.net.cn

spring-boot-starter-securityspring-doc.cadn.net.cn

Spring Security 使用Startersspring-doc.cadn.net.cn

spring-boot-starter-testspring-doc.cadn.net.cn

使用 Starter 测试包含 JUnit Jupiter、Hamcrest 和 Mockito 库的 Spring Boot 应用程序spring-doc.cadn.net.cn

spring-boot-starter-thymeleafspring-doc.cadn.net.cn

使用 Thymeleaf 视图构建 MVC Web 应用程序的 Starterspring-doc.cadn.net.cn

spring-boot-starter-validationspring-doc.cadn.net.cn

使用 Java Bean 验证并结合 Hibernate Validator 的 Starterspring-doc.cadn.net.cn

spring-boot-starter-webspring-doc.cadn.net.cn

基于 Spring MVC 构建 Web 应用程序,包括 RESTful 应用。默认使用 Tomcat 作为嵌入式容器。spring-doc.cadn.net.cn

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

使用 Spring Web 服务的Startersspring-doc.cadn.net.cn

spring-boot-starter-webfluxspring-doc.cadn.net.cn

使用 Spring Framework 的 Reactive Web 支持构建 WebFlux 应用程序的 Starterspring-doc.cadn.net.cn

spring-boot-starter-websocketspring-doc.cadn.net.cn

使用Spring框架MVC WebSocket支持构建WebSocket应用程序的Startersspring-doc.cadn.net.cn

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

表 2. Spring Boot 生产Starters
姓名 <description> </description>

spring-boot-starter-actuatorspring-doc.cadn.net.cn

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

最终,Spring Boot 还包含了以下起步模块(starters),如果您想排除或替换特定的技术方面,可以使用这些模块:spring-doc.cadn.net.cn

表 3. Spring Boot 技术起步包
姓名 <description> </description>

spring-boot-starter-jettyspring-doc.cadn.net.cn

用于将 Jetty 作为嵌入式 Servlet 容器的Starters。spring-boot-starter-tomcat 的替代方案。spring-doc.cadn.net.cn

spring-boot-starter-log4j2spring-doc.cadn.net.cn

用于使用 Log4j2 进行日志记录的Starters。spring-boot-starter-logging 的替代方案。spring-doc.cadn.net.cn

spring-boot-starter-loggingspring-doc.cadn.net.cn

使用 Logback 进行日志记录的 Starter。默认日志记录 Starterspring-doc.cadn.net.cn

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

使用 Reactor Netty 作为嵌入式的响应式 HTTP 服务器的starter。spring-doc.cadn.net.cn

spring-boot-starter-tomcatspring-doc.cadn.net.cn

用于将 Tomcat 作为嵌入式 Servlet 容器的Starters。这是由 spring-boot-starter-web 使用的默认 Servlet 容器Starters。spring-doc.cadn.net.cn

spring-boot-starter-undertowspring-doc.cadn.net.cn

用于将 Undertow 作为嵌入式 Servlet 容器的Starters。spring-boot-starter-tomcat 的替代方案。spring-doc.cadn.net.cn

要了解如何更换技术组件,请参阅更换 Web 服务器日志系统的操作指南文档。spring-doc.cadn.net.cn

对于其他社区贡献的Starters列表,请参见GitHub上https://github.com/spring-projects/spring-boot/tree/main/spring-boot-project/spring-boot-starters/README.adoc模块中的README文件