同以前的properties用法
YAML 是 "YAML Ain't Markup Language"(YAML 不是一种标记语言)的递归缩写。
在开发的这种语言时,YAML 的意思其实是:"Yet Another Markup Language"(仍是一种标记语言)。
非常适合用来做以数据为中心的配置文件
● key: value;kv之间有空格
● 大小写敏感
● 使用缩进表示层级关系
● 缩进不允许使用tab,只允许空格
● 缩进的空格数不重要,只要相同层级的元素左对齐即可
● '#'表示注释
● 字符串无需加引号,如果要加,''与""表示字符串内容 会被 转义/不转义
k: v
行内写法: k: {k1:v1,k2:v2,k3:v3}
#或
k:
k1: v1
k2: v2
k3: v3
行内写法: k: [v1,v2,v3]
#或者
k:
- v1
- v2
- v3
bean层下创建两个类
@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// set,get方法
@ToString //toString方法
public class Pet {
private String name;
private Double weight;
}
resources目录下创建application.yml
person:
userName: zhangsan
boss: true
birth: 2019/12/09
age: 18
interests: #interests: [篮球,足球]
- 篮球
- 足球
animal: [狗,猫]
#score:
#english: 80
#math: 90
score: {english: 80,math: 90}
salarys:
- 99.98
- 99.99
pet:
name: 小白
weight: 30.33
allPets:
sick:
- {name: 小黑,weight: 88.88}
- name: 小蓝
weight: 33.33
- name: 小绿
weight: 22.22
health: [{name: 小白,weight: 66.66},{name: 小银,weight: 77.77}]
controller层创建HelloController类
@RestController
public class HelloController {
@Autowired
Person person;
@RequestMapping("/person")
public Person person(){
return person;
}
}
运行主程序中的main方法,浏览器访问localhost:8080/person即可
配置springboot配置注解处理器
在pom.xml中配置依赖
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-configuration-processorartifactId>
<optional>trueoptional>
dependency>
在pom.xml中的插件位置里面设置打包时不加入配置文件绑定的信息
<configuration>
<excludes>
<exclude>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-configuration-processorartifactId>
exclude>
excludes>
configuration>