简单介绍
YAML 是 "YAML Ain't Markup Language"(YAML 不是一种标记语言)的递归缩写 application.properties和application.yml可以共存 application.properties的配置优先级高于application.yml
基本语法
key: value;kv之间有空格 大小写敏感,例如userName == user-name 使用缩进表示层级关系 缩进不允许使用tab,只允许空格,idea会自动把tab换成空格 缩进的空格数不重要,只要相同层级的元素左对齐即可 '#'表示注释 字符串无需加引号,如果要加,注意转义字符内容的使用 如\n,单引号中作为字符串\\n 输出,双引号会作为\n 输出 如果字符串为一段数字,该数字以零开头,必须添加上"",不然Springboot会将数字解析成八进制 例如String类型配置0815,页面输出结果是815.0
数据类型
字面量:单个的、不可再分的值。date、boolean、string、number、null
k: v
对象:键值对的集合。map、hash、set、object
#行内写法:
k: {k1:v1,k2:v2,k3:v3}
#或
k: k1: v1k2: v2k3: v3
数组:一组按次序排列的值。array、list、queue
#行内写法:
k: [v1,v2,v3]
#或者
k:- v1- v2- v3
实例代码
@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: zhangsanboss: falsebirth: 2019/12/12 20:12:33age: 18pet: name: tomcatweight: 23.4interests: [篮球,游泳]animal: - jerry- marioscore:english: first: 30second: 40third: 50math: [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}]
yaml文件中的提示
比如自己定义的一个类使用yml配置文件进行配置是不会出属性字段的提示,也就是都要自己输入 添加依赖进行属性名提示 配置configuration-processor,若不生效,可以build project 依旧不生效,则可执行mvn clean install -Dmaven.test.skip
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><optional>true</optional>
</dependency>
插件配置排除依赖 优化打包效果,不把依赖引入的类打包,节省空间 新版本springboot自动排除
<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>