SpringBoot基础详解


SpringBoot简介

入门案例

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

入门案例搭建

手动创建方式:

  1. 新建maven项目
  2. 引入依赖

image.png

  1. 创建引导类

image.png

  1. 创建开发控制器类
@RestController
@RequestMapping("/books")
public class BookController {
    @GetMapping("/{id}")
    public String getById(@PathVariable Integer id) {
        System.out.println("id ==> " + id);
        return "hello , spring boot! ";
    }
}
  1. 运行生成的Application类

image.png
SpringBoot脚手架方式

  1. 创建新模块,选择Spring初始化,并配置模块相关基础信息

image.png

  1. 选择当前模块需要使用的技术集

image.png

  1. 开发控制器类
@RestController
@RequestMapping("/books")
public class BookController {
    @GetMapping("/{id}")
    public String getById(@PathVariable Integer id) {
        System.out.println("id ==> " + id);
        return "hello , spring boot! ";
    }
}
  1. 运行自动生成的Application类

image.png

  • Spring程序与SpringBoot程序对比

image.png
注意事项
基于idea开发SpringBoot程序需要确保联网且能够加载到程序框架结构

基于SpringBoot官网创建项目

image.png

SpringBoot项目快速启动

  1. 对SpringBoot项目进行打包(执行Maven构建指令package)
  2. 执行启动指令
java -jar springboot_01_quickstart.jar	# 项目的名称根据实际情况修改

注意
jar支持命令行启动需要依赖maven插件支持,请确定打包时是否具有SpringBoot对应的maven插件

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

SpringBoot概述

起步依赖

  • starter
    • SpringBoot中常见项目名称,定义了当前项目使用的所有项目坐标,以达到减少依赖配置的目的
  • parent
    • 所有SpringBoot项目要继承的项目,定义了若干个坐标版本号(依赖管理,而非依赖),以达到减少依赖冲突的目的
    • spring-boot-starter-parent(2.5.0)与 spring-boot-starter-parent(2.4.6)共计57处坐标版本不同
  • 实际开发
    • 使用任意坐标时,仅书写GAV中的G和A,V由SpringBoot提供
    • 如发生坐标错误,再指定version(要小心版本冲突)

默认配置

tomact默认配置了端口号为8080

基础配置

配置文件格式

修改服务器端口

SpringBoot提供了多种属性配置方式

  • application.properties
server.port=80
  • application.yml
server:
  port: 81
  • application.yaml
server:
  port: 82

SpringBoot配置文件加载顺序

application.properties> application.yml>application.yaml
注意事项

  1. SpringBoot核心配置文件文件名为application
  2. SpringBoot内置属性过多,且所有属性集中在一起修改,在使用时,通过提示键+关键字修改属性

yaml

  • YAML(YAML Ain’t Markup Language),一种数据序列化格式
  • 优点
    • 容易阅读
    • 容易与脚本语言交互
    • 以数据为核心,重数据轻格式
  • YAML文件扩展名
    • .yml(主流)
    • .yaml

yaml语法规则

  • 大小写敏感
  • 属性层级关系使用多行描述,每行结尾使用冒号结束
  • 使用缩进表示层级关系,同层级左侧对其,只允许使用空格(不允许使用Tab键)
  • 属性值前面添加空格(属性名与属性值之间使用冒号+空格作为分隔)
  • #表示注释
  • 核心规则:数据前面加空格与冒号隔开

yaml数组数据

  • 数组数据在数据书写位置的下方使用减号作为数据开始符号,每行书写一个数据,减号与数据中间用空格分割

image.png

yaml数据读取

  • 使用@Value读取单个数据,属性名引用方式:${一级属性名.二级属性名…}

image.png

  • 封装全部数据到Environment对象

image.png

  • 自定义对象封装指定数据(常用)
public class Enterprise {
    private String name;
    private Integer age;
    private String tel;
    private String[] subject;
    //自行添加getter、setter、toString()等方法
}

image.png

  • 自定义对象封装数据警告解决方案

image.png

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-configuration-processor</artifactId>
  <optional>true</optional>
</dependency>

多环境开发配置

多环境启动配置

  • yaml文件多环境启动

image.png
image.png
image.png

  • properties文件多环境启动
#主启动配置文件 application.properties
spring.profiles.active=pro
#环境分类配置文件 application-pro.properties
server.port=80
#环境分类配置文件 application-dev.properties
server.port=81
#环境分类配置文件application-test.properties
server.port=82

多环境启动命令格式

  • 带参数启动SpringBoot
java –jar springboot.jar --spring.profiles.active=test
java –jar springboot.jar --server.port=88
java –jar springboot.jar --server.port=88 --spring.profiles.active=test
  • 参数加载优先顺序

image.png

多环境开发控制

Maven与SpringBoot多环境兼容(步骤)

  1. Maven中设置多环境属性
<profiles>
    <profile>
        <id>dev_env</id>
        <properties>
            <profile.active>dev</profile.active>
        </properties>
        <activation>
            <activeByDefault>true</activeByDefault>
        </activation>
    </profile>
    <profile>
        <id>pro_env</id>
        <properties>
            <profile.active>pro</profile.active>
        </properties>
    </profile>
    <profile>
        <id>test_env</id>
        <properties>
            <profile.active>test</profile.active>
        </properties>
    </profile>
</profiles>
  1. SpringBoot中引入Maven属性

image.png

  1. 执行Maven打包指令
  • Maven指令执行完毕后,生成了对应的包,其中类参与编译,但是配置文件并没有编译,而是复制到包中

image.png

  • 解决思路:对于源码中非java类的操作要求加载Maven对应的属性,解析${}占位符
  1. 对资源文件开启对默认占位符的解析
<build>
    <plugins>
        <plugin>
            <artifactId>maven-resources-plugin</artifactId>
            <configuration>
                <encoding>utf-8</encoding>
                <useDefaultDelimiters>true</useDefaultDelimiters>
            </configuration>
        </plugin>
    </plugins>
</build>
  • Maven打包加载属性,打包顺利通过

image.png

配置文件分类

image.png

  • SpringBoot中4级配置文件
    • 1级: file :config/application.yml 【最高】
    • 2级: file :application.yml
    • 3级:classpath:config/application.yml
    • 4级:classpath:application.yml 【最低】
  • 作用:
    • 1级与2级留做系统打包后设置通用属性
    • 3级与4级用于系统开发阶段设置通用属性

整合第三方技术

整合JUnit

Spring整合JUnit

image.png

SpringBoot整合JUnit

  1. 添加整合Junit起步依赖(可以直接勾选)
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
</dependency>
  1. 编写测试类,默认自动生成了一个
@SpringBootTest
class Springboot07JunitApplicationTests {
    @Autowired
    private BookService bookService;

    @Test
    public void testSave() {
        bookService.save();
    }
}

基于SpringBoot实现SSM整合

  • SpringBoot整合Spring(不存在)
  • SpringBoot整合SpringMVC(不存在)
  • SpringBoot整合MyBatis(主要)
  1. 创建新模块,选择Spring初始化,并配置模块相关基础信息

image.png

  1. 选择当前模块需要使用的技术集(Mybatis,MySQL)

image.png

  1. 设置数据源参数
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
    username: root
    password: root
    type: com.alibaba.druid.pool.DruidDataSource

注意事项
SpringBoot版本低于2.4.3(不含),Mysql驱动版本大于8.0时,需要在url连接串中配置时区,或在MySQL数据库端配置时区解决此问题

jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
  1. 定义数据层接口与映射配置
@Mapper
public interface UserDao {
    @Select("select * from tbl_book where id=#{id}")
    Book getById(Integer id);
}
  1. 测试类中注入dao接口,测试功能
@SpringBootTest
class Springboot08MybatisApplicationTests {
    @Autowired
    private BookDao bookDao;

    @Test
    public void testGetById() {
        Book book = bookDao.getById(1);
        System.out.println(book);
    }
}

SpringBoot实现SSM整合

  1. 创建SpringBoot工程,将三个依赖选中,添加druid依赖
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.2.6</version>
</dependency>
  1. 复制ssm_demo中的各种资源
  2. 删除config包中的所有配置,在BookDao接口上加@Mapper注解
  3. 将application.properties修改成application.yml,配置端口号和连接参数
server:
  port: 80
# todo 4 配置数据库连接参数
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/ssm_db
    username: root
    password: root
    type: com.alibaba.druid.pool.DruidDataSource
  1. 修改BookServiceTest配置类,进行配置
  2. 在static目录中提供index.html页面,跳转到"pages/books.html"
<script>
  location.href="pages/books.html"
</script>

最后运行引导类即可访问 localhost

  • 10
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring BootSpring Framework 基础之上构建的快速开发框架,它可以帮助开发者更快速、更简单地构建基于 Spring 的应用程序。Spring Boot 基于注解配置,注解的使用可以使 Spring Boot 更加简洁、高效。 以下是 Spring Boot 中常用的注解及其详解: 1. @SpringBootApplication:该注解表示这是一个 Spring Boot 应用,它是 Spring Boot 中最重要的注解,相当于同时使用了 @Configuration、@EnableAutoConfiguration 和 @ComponentScan 这三个注解。 2. @RestController:该注解是 Spring MVC 中的注解,表示这是一个 RESTful 风格的控制器,相当于同时使用了 @Controller 和 @ResponseBody 两个注解。 3. @RequestMapping:该注解用于将 HTTP 请求映射到控制器的处理方法上,可以定义请求的 URL、请求的方法(GET、POST 等)、请求的参数等。 4. @PathVariable:该注解用于从请求 URL 中获取路径参数,可以将路径参数传递给控制器的处理方法。 5. @RequestParam:该注解用于从 HTTP 请求中获取请求参数,可以将请求参数传递给控制器的处理方法。 6. @ResponseBody:该注解用于将返回值直接作为 HTTP 响应的内容返回,常用于返回 JSON、XML 等格式的数据。 7. @Autowired:该注解用于自动装配 Spring 容器中的 Bean,可以将 Bean 注入到控制器、服务等组件中。 8. @Service:该注解用于将一个类标记为服务,可以将服务注入到控制器、其他服务等组件中。 9. @Repository:该注解用于将一个类标记为数据访问对象(DAO),可以将 DAO 注入到服务中。 10. @Configuration:该注解用于定义 Spring 配置类,可以使用 @Bean 注解定义 Bean。 11. @Bean:该注解用于定义 Spring Bean,可以指定 Bean 的名称、作用域、初始化方法、销毁方法等属性。 12. @EnableAutoConfiguration:该注解用于自动配置 Spring Boot 应用程序,可以根据类路径和其他条件来决定应该配置哪些 Spring Bean。 以上是 Spring Boot 中常用的注解及其详解,还有其他的注解可以根据实际需求选择使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

@Zeal

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

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

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

打赏作者

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

抵扣说明:

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

余额充值