SpringBoot2第四章:核心技术之SpringBoot配置文件
一、配置文件
1、文件类型
1.1、properties
同properties文件用法
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,只允许空格
- 缩进的空格数不重要,只要相同层级的元素左对齐即可(例如类中对应的属性的层级元素 )
- ’#'表示注释
- 字符串无需加引号,如果要加,’'与""表示字符串内容 会被 转义/不转义
1.2.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
1.2.4、示例
@CnfigurationProperties(prefix = "person)//跟配置文件的前缀进行绑定
@Cmponent//代表注册为容器中的组件
@ToString//lombak的注解
@Data//lombak的注解
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;
}
@CnfigurationProperties(prefix = "person)//跟配置文件的前缀进行绑定
@Cmponent//代表注册为容器中的组件
@ToString//lombak的注解
@Data//lombak的注解
public class Pet {
private String name;
private Double weight;
}
# yaml表示以上对象
person:
userName: “zhangsan \n 李四"
# 单引号会把 \n 作为字符输出 双引号会将 \n 作为换行
# 单引号会进行转义 双引号不会进行转义
boss: true
birth: 2019/12/12 20:12:33
age: 18
# interests: [篮球,足球,排球]
intrersts:
- 篮球
- 足球
- 排球
- 18
animal: [阿猫,阿狗]
socre:
china:100
math:99
english:60
# score: {china:100,math:99,english:60}
salary:
- 8888.8
- 9999.9
pet:
name: 阿狗
weight: 99.99
allpets:
sick:
- {name: 阿狗,weight: 99.99}
- name: 阿猫
weight: 88.88
- name: 阿虫
health:
- {name: 阿花,weight: 99.99}
2、配置提示
自定义的类和配置文件绑定一般没有提示,需要有提示就注入注释处理器。
自定义类绑定的配置提示
//把依赖放到pom.xml文件中
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>-->
<!-- <excludes>-->
<!-- <exclude>-->
<!-- //打包的时候没有这个配置处理器,不会对功能有影响,打包为jar运行时,会对jvm性能有影响,所以去掉,没有则对提示不友好。-->
<!-- <groupId>org.springframework.boot</groupId>-->
<!-- <artifactId>spring-boot-configuration-processor</artifactId>-->
<!-- </exclude>-->
<!-- </excludes>-->
<!-- </configuration>
</plugin>
</plugins>
</build>
<!-- </exclude>-->
<!-- </excludes>-->
<!-- </configuration>
</plugin>
</plugins>
</build>