SpringBoot复习day01

SpringBoot

SprintBoot功能

  • 自动配置

SpringBoot的自动配置是一个运行时(更准确的说,是应用程序启动时)的过程,考虑了众多因素,才决定Spring配置应该用哪个,不该用哪个。该过程是SpringBoot自动完成的。

  • 起步依赖

起步依赖本质上是一个Maven项目对象模型(Project Object Model,POM),定义了对其他库的***传递依赖***,这些东西加在一起即支持某项功能。简单的说,起步依赖就是将具备某种功能的坐标打包到一起,并提供一些默认的功能。

  • 辅助功能

提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。

注意:SpringBoot并不是对Spring功能上的增强,而是提供了一种快速使用Spring的方式。

实现步骤

  1. 创建maven项目
  2. 导入SpringBoot起步依赖
  3. 定义Controller
  4. 编写引导类
  5. 启动测试

导入起步依赖:

<!--    springboot工程需要继承父工程-->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.5.RELEASE</version>
    </parent>

    <dependencies>
<!--        web开发的起始步骤-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>

引导类,项目入口:

/**
 * 引导类。SpringBoot项目的入口
 */
@SpringBootApplication
public class HelloApplication {

    public static void main(String[] args) {
        SpringApplication.run(HelloApplication.class,args);
    }

}

小结

  • SpringBoot在创建项目时,使用jar包的打包方式。
  • SpringBoot的引导类,是项目入口,运行main方法就可以启动项目。
  • 使用SpringBoot和Spring构建的项目,业务代码编写方式完全一样。

SpringBoot起步依赖原理分析

起步依赖原理分析

  1. 在spring-boot-starter-parent中定义了各种技术的版本信息,组合了一套最优搭配的技术版本。
  2. 在各种starter中,定义了完成该功能需要的坐标合集,其中大部分版本信息来自于父工程。
  3. 我们的工程继承parent,引入starter后,通过依赖传递,就可以简单方便获得需要的jar包,并且不会存在版本冲突等问题。

SpringBoot配置

配置文件分类:

SpringBoot是基于约定的,所以很多配置都有默认值,但如果想使用自己的配置替换默认配置的话,就可以使用application.properties或者application.yml (application.yaml)进行配置。

  • properties:
server.properties=8080
  • yml:
server:
  port: 8080

注意:当在同一级目录下,.properties .yml .yaml三个配置文件同时存在的时候,优先级properties>yml>yaml

YAML

YAML全称是YAML Ain’t Markup Language。YAML是一种直观的能够被电脑识别的的数据数据序列化格式,并且容易被人类阅读,容易和脚本语言交互的,可以被支持YAML库的不同的编程语言程序导入,比如:C/C+ +,Ruby, Python,Java, Perl,C#, PHP等。YML文件是以数据为核心的,比传统的xml方式更加简洁。YAML文件的扩展名可以使用.yml或者.yaml。

SpringBoot复习day01_第1张图片

YAML基本语法:
  1. 大小写敏感
  2. 数据值前边必须有空格,作为分隔符
  3. 使用缩进表示层级关系
  4. 缩进时不允许使用Tab键,只允许使用空格(各个系统Tab对应的空格数目可能不同,导致层次混乱)。
  5. 宿进的空格数目不重要,只要相同层级的元素左侧对齐即可
  6. #表示注释,从这个字符一直到行尾,都会被解析器忽略。
YAML:数据格式
  • 对象(map):键值对集合
person:
  name:zhangsan
# 行内写法
person:{name:zhangsan}
  • 数组:一组按次序排列的值
address:
  - beijing
  - shanghai
# 行内写法
address:[beijing,shanghai]
  • 纯量:单个的、不可再分的值
msg1:'hello \n world' #单引忽略转义字符
msg2:”hello \n wordl“ #双引不忽略转义字符
  • 参数引用
name: lisi
    
person:
 	name:${name}  # 引用上边定义的name

SpringBoot读取配置内容

读取配置内容

  • @Value
  • Environment
  • @ConfigurationProperties

example:

    - 1.
    @Value("${person.name}")
    private String name2;
    - 2.
    @Autowired
    private Environment env;
	System.out.println(env.getProperty("person.name"));
    - 3.
    // 加入依赖:
    <dependency>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-configuration-processor</artifactId>
     </dependency>
        
     //Component注解表示  该类会被SpringBoot所识别
     @Component
     // prefix 表示前缀
     // Configuration 表示读取配置信息
     @ConfigurationProperties(prefix = "person")
    public class Person {

    private String name;
    private int age;
    private String[] address;

profile

我们在开发Spring Boot应用时,通常同一套程序会被安装到不同环境,比如:开发、测试、生产等。其中数据库地址、服务器端口等等配置都不同,如果每次打包时,都要修改配置文件,那么非常麻烦。profile功能就是来进行动态配置切换的。

  1. profile配置方式
  • 多profile文件方式
    在这里插入图片描述在这里插入图片描述

  • yml多文档方式

---
server:
  port: 8081
spring:
  profiles: dev
---
server:
  port: 8082
spring:
  profiles: test
---
server:
  port: 8083
spring:
  profiles: pro
---
spring:
  profiles:
    active: pro
  1. profile激活方式
  • 配置文件
  • 虚拟机参数
  • 命令行参数

内置配置加载顺序

SpringBoot程序启动时,会从以下位置加载配置文件:

  1. file:./config/: 当前项目下的/config目录下
  2. file:./ : 当前项目的根目录
  3. classpath:/config/: classpath的/config目录
  4. classpath:/ : classpath的根目录

加载顺序为上文的排列顺序,高优先级配置的属性会生效

外部加载顺序

通过官网查看外部属性加载顺序。

SpringBoot整合其他框架

整合Junit(单元测试)

实现步骤

  1. 搭建SpringBoot工程
  2. 引入starter-test起步依赖
  3. 编写测试类
  4. 添加测试相关注解
  • @RunWith(SpringRunner.class)
  • @SpringBootTest(classes=启动类.class)
  1. 编写测试方法
/**
 * UserServiceTest的测试类
 */
@RunWith(SpringRunner.class)
@SpringBootTest(classes = SpringbootTestApplication.class)
public class UserServiceTest {

    @Autowired
    private UserService userService;

    @Test
    public void testAdd(){
        userService.add();
    }
}
整合MyBatis

实现步骤

  1. 搭建SpringBoot工程
  2. 引入mybatis起步依赖,添加mysql驱动
  3. 编写DataSource和MyBatis相关配置
  4. 定义表和实体类
  5. 编写dao和mapper文件/纯注解kaifa
  6. 测试

注意:如果是.xml的方式整合mybatis,需要在application.yml文件中配置mybatis

example:

# mybatis
 mybatis:
  mapper-locations: classpath:mapper/*Mapper.xml # mapper的映射文件路径
  type-aliases-package: com.itheima.springbootmybatis.domain # 别名
# config-location: # 指定mybatis的核心配置文件啊

你可能感兴趣的:(Java,spring,boot,java,spring)