SSM框架 - SpringBoot_day01:1.SpringBoot简介

SpringBoot

今日目标:

  • 掌握基于SpringBoot框架的程序开发步骤

  • 熟练使用SpringBoot配置信息修改服务器配置

  • 基于SpringBoot的完成SSM整合项目开发

1,SpringBoot简介

SpringBoot 是由 Pivotal 团队提供的全新框架,其设计目的是用来==简化== Spring 应用的==初始搭建==以及==开发过程==。

使用了 Spring 框架后已经简化了我们的开发。而 SpringBoot 又是对 Spring 开发进行简化的,可想而知 SpringBoot 使用的简单及广泛性。既然 SpringBoot 是用来简化 Spring 开发的,那我们就先回顾一下,以 SpringMVC 开发为例:

  1. 创建工程,并在 pom.xml 配置文件中配置所依赖的坐标

  1. 编写 web3.0 的配置类

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

  1. 编写 SpringMVC 的配置类

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

  1. 编写 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 的入门非常简单,只需要:

  1. 构建工程(Idea 或 Spring官网)

  2. 写 Controller

  3. 运行 main() 方法即可

依赖和配置都被自动化处理。

🛠️ 实战理解:

实际开发中,你会发现在 SpringBoot 中根本不需要写 web.xmlapplicationContext.xml,也不再需要手动注册 DispatcherServlet。大大节省时间与出错率!

 


==注意:==

  1. 在创建好的工程中不需要创建配置类

  2. 创建好的项目会自动生成其他的一些文件,而这些文件目前对我们来说没有任何作用,所以可以将这些文件删除。

    可以删除的目录和文件如下:

    • .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 问题导入

以后我们和前端开发人员协同开发,而前端开发人员需要测试前端程序就需要后端开启服务器,这就受制于后端开发人员。为了摆脱这个受制,前端开发人员尝试着在自己电脑上安装 TomcatIdea ,在自己电脑上启动后端程序,这显然不现实。

我们后端可以将 SpringBoot 工程打成 jar 包,该 jar 包运行不依赖于 TomcatIdea 这些工具也可以正常运行,只是这个 jar 包在运行过程中连接和我们自己程序相同的 Mysql 数据库即可。这样就可以解决这个问题,如下图

那现在问题是如何打包呢?

1.1.4.2 打包

由于我们在构建 SpringBoot 工程时已经在 pom.xml 中配置了如下插件

<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
</plugin>

所以我们只需要使用 Mavenpackage 指令打包就会在 target 目录下生成对应的 Jar 包。

==注意:该插件必须配置,不然打好的 jar 包也是有问题的。==

1.1.4.3 启动

进入 jar 包所在位置,在 命令提示符 中输入如下命令

jar -jar springboot_01_quickstart-0.0.1-SNAPSHOT.jar

执行上述命令就可以看到 SpringBoot 运行的日志信息

 

<think> 我们面对的问题是:Invalid bound statement (not found): com.atguigu.springboot_ssm1.mapper.EmpMapper.selectAll 根据引用内容,这个问题通常是由于Mapper接口与对应的XML文件绑定失败导致的。可能的原因包括: 1. XML文件没有正确放置在类路径下(如resources目录),导致编译时没有被复制到target目录。 2. Mapper接口与XML文件的命名不一致(例如,接口名为EmpMapper,XML文件应为EmpMapper.xml)。 3. 在配置文件中(如spring-context.xml或application.properties)没有正确指定mapperLocations。 4. 如果使用了Maven,可能没有配置资源过滤,导致XML文件在打包时没有被包含。 根据引用[3]、[4]、[5]提供的解决方案,我们可以从以下几个方面进行排查: 步骤1:检查XML文件的位置命名 - 确保EmpMapper.xml文件存在,并且其名称与接口名称一致(即EmpMapper.xml)。 - XML文件应该放置在正确的目录下。如果采用Maven项目结构,通常有两种方式: a) 放在src/main/resources目录下,并建立与接口包名相同的目录结构(如com/atguigu/springboot_ssm1/mapper)。 b) 放在src/main/java的对应包目录下,但需要在pom.xml中配置资源包含(因为默认情况下,Maven只打包resources目录下的资源文件)。 步骤2:检查XML文件中的namespaceid - 打开EmpMapper.xml文件,确保namespace属性是Mapper接口的全限定名(com.atguigu.springboot_ssm1.mapper.EmpMapper)。 - 确保有一个id为"selectAll"的SQL语句(如<select id="selectAll" ...>)。 步骤3:检查MyBatis配置 -Spring配置文件中(如spring-context.xml)检查SqlSessionFactoryBean的配置,尤其是mapperLocations属性,确保它能够扫描到XML文件。 例如: <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="mapperLocations" value="classpath*:com/atguigu/springboot_ssm1/mapper/*.xml" /> <!-- 其他配置 --> </bean> - 如果使用注解配置,确保在配置类中指定了mapperLocations。 步骤4:Maven资源过滤配置(如果XML文件放在src/main/java目录下) - 在pom.xml中,添加资源目录配置,使得src/main/java下的xml文件也被包含在构建中。参考引用[4][5]: <build> <resources> <resource> <directory>src/main/resources</directory> <includes> <include>**/*.xml</include> <include>**/*.properties</include> </includes> </resource> <!-- 如果XML文件放在src/main/java下,添加以下配置 --> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> </resources> </build> 步骤5:检查编译后的target目录 - 构建项目后,检查target目录(如target/classes)下是否生成了EmpMapper.xml文件。路径应该是:target/classes/com/atguigu/springboot_ssm1/mapper/EmpMapper.xml。 - 如果没有,说明资源文件没有被正确复制,需要检查上述步骤。 步骤6:检查MyBatis-Spring的配置 - 确保在Spring配置中扫描了Mapper接口,例如使用<mybatis:scan>或@MapperScan注解。 @MapperScan("com.atguigu.springboot_ssm1.mapper") 或者在XML中配置: <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.atguigu.springboot_ssm1.mapper" /> </bean> 步骤7:检查依赖 - 确保MyBatisMyBatis-Spring的版本兼容,且依赖正确。 按照以上步骤排查,通常可以解决该问题。 相关问题: 1. 如何配置MyBatis的mapperLocations? 2. Maven项目如何包含src/main/java下的资源文件? 3. 如何检查MyBatis的SQL映射文件是否正确绑定接口? </think> ### 解决 "Invalid bound statement (not found)" 错误的方法 该错误表明 MyBatis 无法找到 `EmpMapper.selectAll` 方法对应的 SQL 映射配置。以下是系统排查步骤: #### 1. **检查 XML 文件位置与命名规范** - **Mapper 接口路径**: `com.atguigu.springboot_ssm1.mapper.EmpMapper` - **对应 XML 文件路径**: - 若 XML 在 `src/main/resources` 下: `resources/com/atguigu/springboot_ssm1/mapper/EmpMapper.xml` - 若 XML 在 `src/main/java` 下: `java/com/atguigu/springboot_ssm1/mapper/EmpMapper.xml` - **命名规范**: XML 文件名必须与接口名**完全相同**(如 `EmpMapper.xml`)。 #### 2. **验证 XML 文件内容** 确保 `EmpMapper.xml` 包含以下关键配置: ```xml <mapper namespace="com.atguigu.springboot_ssm1.mapper.EmpMapper"> <select id="selectAll" resultType="com.atguigu.springboot_ssm1.entity.Emp"> SELECT * FROM emp_table </select> </mapper> ``` - `namespace`: 必须匹配**Mapper 接口的全限定名**。 - `id="selectAll"`: 必须与接口方法名**严格一致**。 #### 3. **Maven 资源过滤配置(关键步骤)** 在 `pom.xml` 中添加资源包含规则,确保 XML 文件被编译到 `target/classes`: ```xml <build> <resources> <!-- 包含 resources 目录下的 XML --> <resource> <directory>src/main/resources</directory> <includes> <include>**/*.xml</include> </includes> </resource> <!-- 包含 java 目录下的 XML(如有) --> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> </resources> </build> ``` > 引用[4][5]表明,Maven 默认不打包 `src/main/java` 下的非 `.java` 文件,需显式声明[^4][^5]。 #### 4. **检查 MyBatis 配置文件** 在 `application.properties` 或 `SqlSessionFactory` 配置中指定 XML 扫描路径: ```properties # application.properties 配置示例 mybatis.mapper-locations=classpath*:com/atguigu/springboot_ssm1/mapper/*.xml ``` > 引用[3]提到需在 `spring-context.xml` 中配置 `mapperLocations` 属性[^3]。 #### 5. **验证编译结果** 编译后检查 `target/classes` 目录: - 路径 `target/classes/com/atguigu/springboot_ssm1/mapper/` 下必须有 `EmpMapper.xml` 文件。 - 若文件缺失,说明 Maven 未正确打包资源。 #### 6. **其他排查点** - **注解冲突**: 确保接口方法未使用 `@Select` 等注解(避免与 XML 冲突)。 - **包扫描配置**:Spring Boot 启动类添加 `@MapperScan`: ```java @MapperScan("com.atguigu.springboot_ssm1.mapper") @SpringBootApplication public class Application { ... } ``` - **文件编码**: 检查 XML 文件编码是否为 UTF-8(避免特殊字符解析错误)。 --- ### 总结流程 ```mermaid graph TD A[报错: Invalid bound statement] --> B[检查XML路径/命名] B --> C{XML是否存在且规范?} C -->|否| D[修正路径或命名] C -->|是| E[配置Maven资源过滤] E --> F[检查编译后target目录] F --> G{XML在target中?} G -->|否| H[检查pom.xml配置] G -->|是| I[验证MyBatis扫描路径] I --> J[检查@MapperScan] J --> K[完成] ``` ### 相关问题 1. MyBatis 中 `namespace` `id` 的作用是什么? 2. 如何在 Spring Boot 中配置多模块的 MyBatis 映射文件路径? 3. Maven 资源过滤配置无效的可能原因有哪些? [^1]: 绑定异常通常由 XML 映射文件缺失或配置错误引起。 [^3]: 需在 `SqlSessionFactoryBean` 中明确指定 `mapperLocations`。 [^4]: Maven 需显式包含 `src/main/java` 下的 XML 文件。 [^5]: 资源目录配置是解决该问题的常见方案。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏驰和徐策

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值