
SpringBoot
今日目标:
掌握基于SpringBoot框架的程序开发步骤
熟练使用SpringBoot配置信息修改服务器配置
基于SpringBoot的完成SSM整合项目开发
1,SpringBoot简介
SpringBoot 是由 Pivotal 团队提供的全新框架,其设计目的是用来==简化== Spring 应用的==初始搭建==以及==开发过程==。
使用了 Spring 框架后已经简化了我们的开发。而 SpringBoot 又是对 Spring 开发进行简化的,可想而知 SpringBoot 使用的简单及广泛性。既然 SpringBoot 是用来简化 Spring 开发的,那我们就先回顾一下,以 SpringMVC 开发为例:
-
创建工程,并在
pom.xml配置文件中配置所依赖的坐标

-
编写
web3.0的配置类作为
web程序,web3.0的配置类不能缺少,而这个配置类还是比较麻烦的,代码如下

-
编写
SpringMVC的配置类

做到这只是将工程的架子搭起来。要想被外界访问,最起码还需要提供一个 Controller 类,在该类中提供一个方法。
-
编写
Controller类

从上面的 SpringMVC 程序开发可以看到,前三步都是在搭建环境,而且这三步基本都是固定的。SpringBoot 就是对这三步进行简化了。接下来我们通过一个入门案例来体现 SpingBoot 简化 Spring 开发。
📖 理论理解:
SpringBoot 是 Spring 官方推出的一个快速开发框架,用来简化 Spring 应用的配置与部署过程。它核心理念是**“约定优于配置”**,通过自动配置、starter依赖和内嵌容器,实现“开箱即用”。
🛠️ 实战理解:
我们以前开发一个 Spring + SpringMVC + MyBatis 的项目,起步阶段需要配置大量 XML,整合依赖非常繁琐。而使用 SpringBoot,只需要一个 Application 启动类 + 少量注解就能跑起来,显著提升开发效率。
1.1 SpringBoot快速入门
1.1.1 开发步骤
SpringBoot 开发起来特别简单,分为如下几步:
-
创建新模块,选择Spring初始化,并配置模块相关基础信息
-
选择当前模块需要使用的技术集
-
开发控制器类
-
运行自动生成的Application类
知道了 SpringBoot 的开发步骤后,接下来我们进行具体的操作
1.1.1.1 创建新模块
-
点击
+选择New Module创建新模块

-
选择
Spring Initializr,用来创建SpringBoot工程以前我们选择的是
Maven,今天选择Spring Initializr来快速构建SpringBoot工程。而在Module SDK这一项选择我们安装的JDK版本。

-
对
SpringBoot工程进行相关的设置我们使用这种方式构建的
SpringBoot工程其实也是Maven工程,而该方式只是一种快速构建的方式而已。
==注意:打包方式这里需要设置为
Jar== -
选中
Web,然后勾选Spring Web由于我们需要开发一个
web程序,使用到了SpringMVC技术,所以按照下图红框进行勾选

-
下图界面不需要任何修改,直接点击
Finish完成SpringBoot工程的构建

经过以上步骤后就创建了如下结构的模块,它会帮我们自动生成一个 Application 类,而该类一会再启动服务器时会用到

📖 理论理解:
SpringBoot 的入门非常简单,只需要:
-
构建工程(Idea 或 Spring官网)
-
写 Controller
-
运行
main()方法即可
依赖和配置都被自动化处理。
🛠️ 实战理解:
实际开发中,你会发现在 SpringBoot 中根本不需要写 web.xml、applicationContext.xml,也不再需要手动注册 DispatcherServlet。大大节省时间与出错率!
==注意:==
在创建好的工程中不需要创建配置类
创建好的项目会自动生成其他的一些文件,而这些文件目前对我们来说没有任何作用,所以可以将这些文件删除。
可以删除的目录和文件如下:
.mvn
.gitignore
HELP.md
mvnw
mvnw.cmd
📖 理论理解:
SpringBoot 工程以 Maven 模块构建为基础,通过继承 spring-boot-starter-parent,引入版本管理与依赖。
🛠️ 实战理解:
创建后工程会自动生成如下结构:
├── Application.java // 启动类(含 main 方法)
└── controller/BookController.java // 控制器类
项目初始结构干净、统一,利于多人协作、持续集成。
1.1.1.2 创建 Controller
在 com.itheima.controller 包下创建 BookController ,代码如下:
@RestController
@RequestMapping("/books")
public class BookController {
@GetMapping("/{id}")
public String getById(@PathVariable Integer id){
System.out.println("id ==> "+id);
return "hello , spring boot!";
}
}
📖 理论理解:
@RestController = @Controller + @ResponseBody,用于 RESTful 接口开发。
@GetMapping("/{id}")
public String getById(@PathVariable Integer id)
代表处理 GET 请求 /books/1 这样的 URL,@PathVariable 用于取 URL 中的参数。
🛠️ 实战理解:
实际项目中这种方式用于开发 REST API,例如“根据图书 ID 查询图书”,在前后端分离系统中尤为常见。
1.1.1.3 启动服务器
运行 SpringBoot 工程不需要使用本地的 Tomcat 和 插件,只运行项目 com.itheima 包下的 Application 类,我们就可以在控制台看出如下信息

📖 理论理解:
SpringBoot 默认内嵌 Tomcat,通过执行 main() 方法启动,不依赖外部 Tomcat 服务器。
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
🛠️ 实战理解:
部署到测试服务器、云平台时只需打包 .jar,部署运行都更方便(统一入口、跨平台兼容性强)。
1.1.1.4 进行测试
使用 Postman 工具来测试我们的程序

通过上面的入门案例我们可以看到使用 SpringBoot 进行开发,使整个开发变得很简单,那它是如何做到的呢?
要研究这个问题,我们需要看看 Application 类和 pom.xml 都书写了什么。先看看 Applicaion 类,该类内容如下:
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
这个类中的东西很简单,就在类上添加了一个 @SpringBootApplication 注解,而在主方法中就一行代码。我们在启动服务器时就是执行的该类中的主方法。
再看看 pom.xml 配置文件中的内容
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!--指定了一个父工程,父工程中的东西在该工程中可以继承过来使用-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.0</version>
</parent>
<groupId>com.itheima</groupId>
<artifactId>springboot_01_quickstart</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!--JDK 的版本-->
<properties>
<java.version>8</java.version>
</properties>
<dependencies>
<!--该依赖就是我们在创建 SpringBoot 工程勾选的那个 Spring Web 产生的-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--这个是单元测试的依赖,我们现在没有进行单元测试,所以这个依赖现在可以没有-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<!--这个插件是在打包时需要的,而这里暂时还没有用到-->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
我们代码之所以能简化,就是因为指定的父工程和 Spring Web 依赖实现的。具体的我们后面在聊。
📖 理论理解:
使用 Postman 发送请求测试接口即可,无需部署到远程服务器。
🛠️ 实战理解:
项目开发初期可以用 Postman 快速调试接口逻辑,验证入参出参,后期可用 Swagger 文档或集成前端联调。
1.1.2 对比
做完 SpringBoot 的入门案例后,接下来对比一下 Spring 程序和 SpringBoot 程序。如下图

-
坐标
Spring程序中的坐标需要自己编写,而且坐标非常多SpringBoot程序中的坐标是我们在创建工程时进行勾选自动生成的 -
web3.0配置类
Spring程序需要自己编写这个配置类。这个配置类大家之前编写过,肯定感觉很复杂SpringBoot程序不需要我们自己书写 -
配置类
Spring/SpringMVC程序的配置类需要自己书写。而SpringBoot程序则不需要书写。
==注意:基于Idea的
Spring Initializr快速构建SpringBoot工程时需要联网。==
🧠 理论理解:
SpringBoot 的本质是:封装传统配置,默认集成,简化流程,提升开发效率。
🛠️ 实战理解:
新项目 99% 都选择 SpringBoot 起步;老项目也逐渐迁移(SpringCloud 全系基于 SpringBoot 构建)。
1.1.3 官网构建工程
在入门案例中之所以能快速构建 SpringBoot 工程,是因为 Idea 使用了官网提供了快速构建 SpringBoot 工程的组件实现的。那如何在官网进行工程构建呢?通过如下步骤构建
1.1.3.1 进入SpringBoot官网
官网地址如下:
https://spring.io/projects/spring-boot
进入到 SpringBoot 官网后拖到最下方就可以看到如下内容

然后点击 Spring Initializr 超链接就会跳转到如下页面

这个页面内容是不是感觉很眼熟的,这和我们使用 Idea 快速构建 SpringBoot 工程的界面基本相同。在上面页面输入对应的信息
1.1.3.2 选择依赖
选择 Spring Web 可以点击上图右上角的 ADD DEPENDENCIES... CTRL + B 按钮,就会出现如下界面

1.1.3.3 生成工程
以上步骤完成后就可以生成 SpringBoot 工程了。在页面的最下方点击 GENERATE CTRL + 回车 按钮生成工程并下载到本地,如下图所示

打开下载好的压缩包可以看到工程结构和使用 Idea 生成的一模一样,如下图
而打开 pom.xml 文件,里面也包含了父工程和 Spring Web 的依赖。
通过上面官网的操作,我们知道 Idea 中快速构建 SpringBoot 工程其实就是使用的官网的快速构建组件,那以后即使没有 Idea 也可以使用官网的方式构建 SpringBoot 工程。
📖 理论理解:
官网 https://start.spring.io 提供一键项目生成器,可以选依赖、语言、版本等,生成标准结构项目压缩包。
🛠️ 实战理解:
-
离线开发 / 没装 IDEA 时也能快速生成项目;
-
工程结构统一,方便培训新人、与团队同步标准;
-
Idea 也是基于官网的 API 接口构建项目(Spring Initializr)。
1.1.4 SpringBoot工程快速启动
1.1.4.1 问题导入

以后我们和前端开发人员协同开发,而前端开发人员需要测试前端程序就需要后端开启服务器,这就受制于后端开发人员。为了摆脱这个受制,前端开发人员尝试着在自己电脑上安装 Tomcat 和 Idea ,在自己电脑上启动后端程序,这显然不现实。
我们后端可以将 SpringBoot 工程打成 jar 包,该 jar 包运行不依赖于 Tomcat 和 Idea 这些工具也可以正常运行,只是这个 jar 包在运行过程中连接和我们自己程序相同的 Mysql 数据库即可。这样就可以解决这个问题,如下图

那现在问题是如何打包呢?
1.1.4.2 打包
由于我们在构建 SpringBoot 工程时已经在 pom.xml 中配置了如下插件
<plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin>
所以我们只需要使用 Maven 的 package 指令打包就会在 target 目录下生成对应的 Jar 包。
==注意:该插件必须配置,不然打好的
jar包也是有问题的。==
1.1.4.3 启动
进入 jar 包所在位置,在 命令提示符 中输入如下命令
jar -jar springboot_01_quickstart-0.0.1-SNAPSHOT.jar
执行上述命令就可以看到 SpringBoot 运行的日志信息


989

被折叠的 条评论
为什么被折叠?



