简介
yaml文件其实也是一种配置文件,相比较ini和config来说功能更加强大,使用更加简单,操作更加灵活。yaml文件可以存储键值对,对象,数组。
它的基本语法规则如下:
- 大小写敏感
- 使用缩进表示层级关系
- 缩进时不允许使用Tab键,只允许使用空格。
- 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
简单配置
直接上代码:
#普通的key-value
name: yin
#对象
student:
name: yin
age: 3
#对象的行内写法
student2: {name: yin,age: 3}
#存数组
#方式一:
pets:
- cat
- dog
- pig
#方式2:
pets2: [cat,dog,pig]
复合结构:
person:
name: 殷会东
age: 3
happy: true
date: 2019/01/02
maps: {k1: v1,k2: v2}
lists:
- code
- music
dog:
name: 旺财
age: 3
详细见下图:
动态表达式
person:
name: 殷会东-${random.uuid} #生成一个随机的uuid
age: ${random.int} #生成一个随机的int值
happy: true
date: 2019/01/02
maps: {k1: v1,k2: v2}
address: 丰奥嘉园
lists:
- code
- music
dog:
name: 旺财-${person.address:流浪狗} #如果能找到person.address就用存在的值代替,不存在就用冒号后边默认的值
age: 3
输出:
Person(
name=殷会东-b61565f7-5152-46ce-967b-be4050f812c8,
age=907361169,
happy=true,
date=Wed Jan 02 00:00:00 CST 2019,
maps={k1=v1, k2=v2},
lists=[code, music],
dog=Dog(name=旺财-丰奥嘉园, age=3)
)
导入实体类
方式一
在要导入的实体类上加上 @ConfigurationProperties(prefix = “person”) 注解 --将配置文件中的配置的每一个属性的值,映射到这个组件中,利用 参数prefix=”配置文件中的名“精确配置;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Component
@ConfigurationProperties(prefix = "person")
public class Person {
private String name;
private Integer age;
private Boolean happy;
private Date date;
private Map<String,Object> maps;
private List<Object> lists;
private Dog dog;
}
方式二
使用value注入
public class Dog {
@Value("#{person.dog.name}")
private String name;
@Value("#{person.dog.age}")
private Integer age;
}
输出:
方式三
使用@pro