1、简介
YAML是 “YAML Ain’t a Markup Language” (YAML不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:“Yet Another Markup Language”(仍是一种标记语言)
这种语言以数据作为中心,而不是以标记语言为重点!
以前的配置文件,大多数都是使用xml来配置;比如一个简单的端口配置,我们来对比下yaml和xml
传统xml配置:
<server>
<port>8081<port>
</server>
yaml配置:
server:
prot: 8080
2、yaml基础语法
- key: value;kv之间有空格
- 大小写敏感
- 使用缩进表示层级关系
- 缩进不允许使用tab,只允许空格
- 缩进的空格数不重要,只要相同层级的元素左对齐即可
- '#'表示注释
- 字符串无需加引号,如果要加,’'与""表示字符串内容 会被 转义/不转义
3、数据类型
- 字面量:单个的、不可再分的值。date、boolean、string、number、null
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
4、yaml注入配置文件
1、实体类Persion
/*
@ConfigurationProperties作用:
将配置文件中配置的每一个属性的值,映射到这个组件中;
告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定
参数 prefix = “person” : 将配置文件中的person下面的所有属性一一对应
*/
@Component //注册bean
@ConfigurationProperties(prefix = "persion")
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Persion {
private String name;
private int age;
private String[] taste;//兴趣
}
2、application.yaml
persion:
name: 张三
age: 18
taste:
- 唱歌
- 跳舞
- 敲代码
3、发送请求测试
@RestController
public class Yamlcontroller {
@Autowired
private Persion persion;
@RequestMapping("/yaml")
public String yaml(){
String[] taste = persion.getTaste();
String total = "姓名:" +persion.getName() + "年龄:" + persion.getAge() + "爱好:"+ Arrays.toString(taste);
System.out.println(total);
return total;
}
}
5、配置提示
自定义的类和配置文件绑定一般没有提示。
//加上这个依赖,在配置文件中配置我们自定义的类就会有提示,快去试一下吧。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
//打成jar包的时候如果我们不剔除这个提示配置依赖那么我们就会加载很多类,会造成负担。
<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>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>