SpringBoot2核心功能--01配置文件
1、文件类型
1.1、properties
同以前的properties用法
和yaml配置文件同时使用时, 两个配置文件都会生效,不过properties文件会先生效。
1.2、yaml
1.2.1、简介
YAML 是 “YAML Ain’t Markup Language”(YAML 不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:“Yet Another Markup Language”(仍是一种标记语言)。
非常适合用来做以数据为中心的配置文件
1.2.2、基本语法
- key: value;kv之间有空格
- 大小写敏感
- 使用缩进表示层级关系
- 缩进不允许使用tab,只允许空格
- 缩进的空格数不重要,只要相同层级的元素左对齐即可
- '#'表示注释
- 字符串无需加引号,如果要加,’'与""表示字符串内容 会被 转义/不转义
1.2.3、数据类型
- 字面量:单个的、不可再分的值。date、boolean、string、number、null
k: v
- 对象:键值对的集合。map、hash、set、object
行内写法: k: {k1:v1,k2:v2,k3:v3}
#或
k:
k1: v1
k2: v2
k3: v3
- 数组:一组按次序排列的值。array、list、queue
行内写法: k: [v1,v2,v3]
#或者
k:
- v1
- v2
- v3
1.2.4、示例
@ConfigurationProperties(prefix = "person")
@Component
@Data
@ToString
public class Person {
private String userName;
private Boolean boss;
private Date birth;
private Integer age;
private Pet pet;
private String[] interests;
private List<String> animal;
private Map<String, Object> score;
private Set<Double> salarys;
private Map<String, List<Pet>> allPets;
}
@Data
@ToString
public class Pet {
private String name;
private Double weight;
}
# yaml形式的配置文件表示以上对象
person:
# 1、基本的字面量的写法
userName: zhangsan
# userName: "zhangsan \n 李四"
# userName: 'zhangsan \n 李四'
# 在控制台输出时:
# 单引号会转义,会将\n作为字符串输出;
# 双引号不会转义,会将\n按原义,即换行输出
boss: false
birth: 2021/1/1
age: 1
# 2、对象变量
pet:
name: 旺财
weight: 10
# 3、数组形式的写法有以下两种
#interest: ["篮球","足球","排球"]
interest:
- 篮球
- 足球
- 排球
#animsl: ["阿猫","阿狗"]
animal:
- 阿猫
- 阿狗
#salarys: [1000.00,9999.99]
salarys:
- 9999.99
- 100000000000.00
# 3、Map集合形式的写法,有以下两种写法
#score: {english: 80,math: 150}
score:
english: 80
math: 150
allPets:
sick:
- {name: sick01,weigth: 2}
- name: sick02
weight: 3
- name: sick03
weight: 4
health: [{name: health01,weight: 5},{name: health02,weight: 6}]
2、配置提示
自定义的类和配置文件绑定一般没有提示。
配置提示设置官方文档
<!--该包对功能没多大影响,只是方便开发
导入该依赖后以后在yml配置文件中写自定义对象的属性时会有提示-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<!--导入该配置可以设置在将项目打包时不包含该spring-boot-configuration-processor包,
目的是为了让jvm启动时不检索那么多没用的jar包-->
<configuration>
<excludes>
<exclude>
<!--在此引入不需要打包的依赖-->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>