目录
1、文件类型
1.1、properties
1.1.1、文件形式
1.2、yaml
1.2.1、简介
1.2.2、基本语法
1.2.3、数据类型
1.2.4、示例
2、配置提示
2.1、引入依赖
2.2、在springBoot打包插件中加入下述代码
1、文件类型
1.1、properties
1.1.1、文件形式
dbPort = localhost
databaseName = mydb
dbUserName = root
dbPassword = root
1.2、yaml
1.2.1、简介
yaml是一种标记语言,适合用来做以数据为中心的配置文件。
1.2.2、基本语法
- key: value;kv之间有空格
- 大小写敏感
- 使用缩进表示层级关系
- 缩进不允许使用tab,只允许空格
- 缩进的空格数不重要,只要相同层级的元素左对齐即可
- '#'表示注释
- 字符串无需加引号,如果要加,' '与" "表示字符串内容会被 '不转义'/"转义"
1.2.3、数据类型
????????1、字面量:单个的、不可再分的值。date、boolean、string、number、null
k:v
? ? ? ? 2、对象:键值对的集合。map、hash、set、object
行内写法: k: {k1:v1,k2:v2,k3:v3}
#或
k:
k1: v1
k2: v2
k3: v3
? ? ? ? 3、数组:一组按次序排列的值。array、list、queue
行内写法: k: [v1,v2,v3]
#或者
k:
- v1
- v2
- v3
1.2.4、示例
????????用yaml表示Java对象:
????????Java对象:
//与application.yaml文件中的person对象进行绑定
@ConfigigurationProperties(perfix="person")
@Component
@ToString
@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文件:
# yaml表示以上对象
person:
userName: zhangsan
boss: false
birth: 2019/12/12 20:12:33
age: 18
pet:
name: tomcat
weight: 23.4
interests: [篮球,游泳]
animal:
- jerry
- mario
score:
english:
first: 30
second: 40
third: 50
math: [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}]
2、配置提示
????????自定义的类和配置文件绑定一般没有提示。
2.1、引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
2.2、在springBoot打包插件中加入下述代码
? ? ? ? 因为配置提示只在开发中需要,在代码实际运行中不需要,故加入下述代码可以防止将上述配置提示插件打包至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>
|