1 文件类型
1.1 properties
同以前的properties用法
注意:properties的配置优先级高于yml
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,只允许空格
-
缩进的空格数不重要,只要相同层级的元素左对齐即可
-
‘#’ 表示注释
-
字符串无需加引号,如果要加,
''
与""
表示字符串内容 会被 转义/不转义- 如
\n
,单引号中作为字符串输出,双引号会换行 - 如果字符串为一段数字,该数字以零开头,必须添加上
""
不然Springboot会将数字解析成八进制
- 如
1.2.3、数据类型
- 字面量:单个的、不可再分的值。date、boolean、string、number、null
k: v
- 对象:键值对的集合。map、hash、object
行内写法: k: {
k1:v1,k2:v2,k3:v3}
#或
k:
k1: v1
k2: v2
k3: v3
- 数组:一组按次序排列的值。array、list、queue、set
行内写法: k: [v1,v2,v3]
#或者
k:
- v1
- v2
- v3
1.2.4、示例
@Data
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
public class Pet {
private String name;
private Double weight;
}
# yaml表示以上对象
person:
# username: 'zhangsan \n 李四'
# 单引号会将 \n 作为 字符串 输出
username: "zhangsan \n 李四"
# 双引号会将 \n 作为 换行 输出
# 双引号不会转义,单引号会转义
boss: true
birth: 2019/12/9
age: 2
# interests: [篮球,足球]
interests:
- 篮球
- 足球
- 18
animal: [小猫,小狗]
# score:
# english: 80
# math: 90
score: {
english:80,math:90}
salarys:
- 9999.98
- 9999.99
pet:
name: 小狗
weight: 50
allPets:
sick:
- {
name: 小狗,weight: 50}
- name: 小猫
weight: 66
- name: 小花
weight: 77
health:
- {
name: 小红,weight: 99}
- {
name: 小明,weight: 88}
2 配置提示
自定义的类和配置文件绑定一般没有提示,故为了编写方便,使用如下依赖可以有配置提示,且在2.5.6版本中,打包时已自动去除该依赖。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>