目录
1、文件类型
1.1、properties
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
String 类型可以使用单引号或双引号表示
# 单引号会将 \n 作为字符串输出,双引号会将 \n 作为换行输出
# 单引号不会使转义字符生效,双引号会使转义字符生效
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、示例
① 引入lombok依赖,创建两个类
@Component
@ConfigurationProperties(prefix = "person")
@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 的配置文件,application.yaml,后缀也可以是 yml
person:
userName: zhangsan
boss: false
birth: 2019/12/12 20:12:33
age: 18
pet:
name: tomcat
weight: 23.4
interests: [ 篮球,游泳 ]
animal:
- jerry
- mario
score:
english:
first: 30
second: 40
third: 50
math: [ 131,140,148 ]
chinese: { first: 128,second: 136 }
salarys: [ 3999,4999.98,5999.99 ]
allPets:
sick:
- { name: tom }
- { name: jerry,weight: 47 }
health: [ { name: mario,weight: 47 } ]
2、配置提示
自定义的类和配置文件绑定一般没有提示。且会提示未配置 SpringBoot 配置注解处理器
这时只需添加依赖
<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>
<configuration>
<excludes>
<exclude>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>