本章概要
- SpringBoot3 简介
- 系统要求
- 快速入门
- 入门总结
1.1 SpringBoot3 简介
此处使用
SpringBoot
版本:3.0.5
https://docs.spring.io/spring-boot/docs/current/reference/html/getting-started.html
无论使用XML、注解、Java配置类还是他们的混合用法,都会觉得配置文件过于复杂和繁琐,让人头疼!
SpringBoot
帮我们简单、快速地创建一个独立的、生产级别的 Spring
应用(说明:SpringBoot
底层是Spring
),大多数SpringBoot
应用只需要编写少量配置即可快速整合Spring
平台以及第三方技术!
SpringBoot
的主要目标是:
- 为所有
Spring
开发提供更快速、可广泛访问的入门体验。 - 开箱即用,设置合理的默认值,但是也可以根据需求进行适当的调整。
- 提供一系列大型项目通用的非功能性程序(如嵌入式服务器、安全性、指标、运行检查等)。
- 约定大于配置,基本不需要主动编写配置类、也不需要
XML
配置文件。
总结:简化开发,简化配置,简化整合,简化部署,简化监控,简化运维。
1.2 系统要求
技术&工具 | 版本(or later) |
---|---|
maven | 3.6.3 or later 3.6.3 或更高版本 |
Tomcat | 10.0+ |
Servlet | 9.0+ |
JDK | 17+ |
1.3 快速入门
场景:浏览器发送
/hello
请求,返回Hello,Spring Boot 3!
- 开发步骤
- 创建
Maven
工程 - 添加依赖(
springboot
父工程依赖 ,web
启动器依赖) - 编写启动引导类(
springboot
项目运行的入口) - 编写处理器
Controller
- 启动项目
- 创建项目
- 添加依赖
- 添加父工程坐标
SpringBoot
可以帮我们方便的管理项目依赖 , 在SpringBoot
提供了一个名为spring-boot-starter-parent
的工程,里面已经对各种常用依赖的版本进行了管理,我们的项目需要以这个项目为父工程,这样我们就不用操心依赖的版本问题了,需要什么依赖,直接引入坐标(不需要添加版本)即可!
<!--所有springboot项目都必须继承自 spring-boot-starter-parent-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.0.5</version>
</parent>
- 添加
web
启动器
为了让
SpringBoot
帮我们完成各种自动配置,我们必须引入SpringBoot
提供的自动配置依赖,我们称为启动器。
因为是web
项目,这里我们引入web
启动器,在pom.xml
文件中加入如下依赖:
<dependencies>
<!--web开发的场景启动器-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
- 创建启动类
创建 package:com.atguigu
创建启动类:MainApplication
package com.atguigu;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* @SpringBootApplication是一个特殊的注解,用于标识一个Spring Boot应用程序的入口类。它的主要作用是将三个常用注解组合在一起,简化了配置的过程。
*
* 具体而言,@SpringBootApplication注解包含以下三个注解的功能:
* @Configuration:将该类标识为应用程序的配置类。它允许使用Java代码定义和配置Bean。
* @EnableAutoConfiguration:启用Spring Boot的自动配置机制。它根据项目的依赖项自动配置Spring应用程序的行为。自动配置根据类路径、注解和配置属性等条件来决定要使用的功能和配置。
* @ComponentScan:自动扫描并加载应用程序中的组件,如控制器、服务、存储库等。它默认扫描@SpringBootApplication注解所在类的包及其子包中的组件。
*
* 使用@SpringBootApplication注解,可以将上述三个注解的功能集中在一个注解上,简化了配置文件的编写和组件的加载和扫描过程。它是Spring Boot应用程序的入口点,标识了应用程序的主类,
* 并告诉Spring Boot在启动时应如何配置和加载应用程序。
*/
@SpringBootApplication
public class MainApplication {
//SpringApplication.run() 方法是启动 Spring Boot 应用程序的关键步骤。它创建应用程序上下文、
// 自动配置应用程序、启动应用程序,并处理命令行参数,使应用程序能够运行和提供所需的功能
public static void main(String[] args) {
SpringApplication.run(MainApplication.class,args);
}
}
- 编写处理器 Controller
创建package:com.atguigu.controller
创建类:HelloController
注意:IoC
和DI
注解需要在启动类的同包或者子包下方可生效!无需指定,约束俗称。
package com.atguigu.controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class HelloController {
@GetMapping("/hello")
public String hello(){
return "Hello,Spring Boot 3!";
}
}
1.4 入门总结
- 为什么依赖不需要写版本?
- 每个boot项目都有一个父项目
spring-boot-starter-parent
- parent的父项目是
spring-boot-dependencies
- 父项目 版本仲裁中心,把所有常见的jar的依赖版本都声明好了
- 比如:
mysql-connector-j
- 启动器(
Starter
)是何方神圣?
Spring Boot
提供了一种叫做Starter
的概念,它是一组预定义的依赖项集合,旨在简化Spring
应用程序的配置和构建过程。Starter
包含了一组相关的依赖项,以便在启动应用程序时自动引入所需的库、配置和功能
主要作用如下:
- 简化依赖管理:
Spring Boot Starter
通过捆绑和管理一组相关的依赖项,减少了手动解析和配置依赖项的工作。只需引入一个相关的Starter
依赖,即可获取应用程序所需的全部依赖。 - 自动配置:
Spring Boot Starter
在应用程序启动时自动配置所需的组件和功能。通过根据类路径和其他设置的自动检测,Starter
可以自动配置Spring Bean
、数据源、消息传递等常见组件,从而使应用程序的配置变得简单和维护成本降低。 - 提供约定优于配置:
Spring Boot Starter
遵循“约定优于配置”的原则,通过提供一组默认设置和约定,减少了手动配置的需要。它定义了标准的配置文件命名约定、默认属性值、日志配置等,使得开发者可以更专注于业务逻辑而不是繁琐的配置细节。 - 快速启动和开发应用程序:
Spring Boot Starter
使得从零开始构建一个完整的Spring Boot
应用程序变得容易。它提供了主要领域(如Web
开发、数据访问、安全性、消息传递等)的Starter
,帮助开发者快速搭建一个具备特定功能的应用程序原型。 - 模块化和可扩展性:
Spring Boot Starter
的组织结构使得应用程序的不同模块可以进行分离和解耦。每个模块可以有自己的Starter
和依赖项,使得应用程序的不同部分可以按需进行开发和扩展。
Spring Boot
提供了许多预定义的Starter
,例如spring-boot-starter-web
用于构建Web
应用程序,spring-boot-starter-data-jpa
用于使用JPA进行数据库访问,spring-boot-starter-security
用于安全认证和授权等等。
使用Starter
非常简单,只需要在项目的构建文件(例如Maven
的pom.xml
)中添加所需的Starter
依赖,Spring Boot
会自动处理依赖管理和配置。
通过使用Starter
,开发人员可以方便地引入和配置应用程序所需的功能,避免了手动添加大量的依赖项和编写冗长的配置文件的繁琐过程。同时,Starter
也提供了一致的依赖项版本管理,确保依赖项之间的兼容性和稳定性。
spring boot
提供的全部启动器地址:
https://docs.spring.io/spring-boot/docs/current/reference/html/using.html#using.build-systems.starters
命名规范:
- 官方提供的场景:命名为:
spring-boot-starter-*
- 第三方提供场景:命名为:
*-spring-boot-starter
@SpringBootApplication
注解的功效?
@SpringBootApplication
添加到启动类上,是一个组合注解,他的功效有具体的子注解实现!
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan
public @interface SpringBootApplication {}
@SpringBootApplication
注解是Spring Boot
框架中的核心注解,它的主要作用是简化和加速Spring Boot
应用程序的配置和启动过程。
具体而言,@SpringBootApplication
注解起到以下几个主要作用:
- 自动配置:
@SpringBootApplication
注解包含了@EnableAutoConfiguration
注解,用于启用Spring Boot
的自动配置机制。自动配置会根据应用程序的依赖项和类路径,自动配置各种常见的Spring
配置和功能,减少开发者的手动配置工作。它通过智能地分析类路径、加载配置和条件判断,为应用程序提供适当的默认配置。 - 组件扫描:
@SpringBootApplication
注解包含了@ComponentScan
注解,用于自动扫描并加载应用程序中的组件,例如控制器(Controllers
)、服务(Services
)、存储库(Repositories
)等。它默认会扫描@SpringBootApplication
注解所在类的包及其子包中的组件,并将它们纳入Spring Boot
应用程序的上下文中,使它们可被自动注入和使用。 - 声明配置类:
@SpringBootApplication
注解本身就是一个组合注解,它包含了@Configuration
注解,将被标注的类声明为配置类。配置类可以包含Spring
框架相关的配置、Bean
定义,以及其他的自定义配置。通过@SpringBootApplication
注解,开发者可以将配置类与启动类合并在一起,使得配置和启动可以同时发生。
总的来说,**@SpringBootApplication**
注解的主要作用是简化**Spring Boot**
应用程序的配置和启动过程。它自动配置应用程序、扫描并加载组件,并将配置和启动类合二为一,简化了开发者的工作量,提高了开发效率。