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

    1. k: v
  • 对象:键值对的集合。map、hash、set、object

    1. 行内写法: k: {k1:v1,k2:v2,k3:v3}
    2. #或
    3. k:
    4. k1: v1
    5. k2: v2
    6. k3: v3
  • 数组:一组按次序排列的值。array、list、queue

    1. 行内写法: k: [v1,v2,v3]
    2. #或者
    3. k:
    4. - v1
    5. - v2
    6. - v3

    1.2.4、示例

  • Person.java ```java @Data public class Person {

    private String userName; private Boolean boss; private Date birth; private Integer age; private Pet pet; private String[] interests; private List animal; private Map score; private Set salarys; private Map> allPets; }

@Data public class Pet { private String name; private Double weight; }

  1. - application.yml
  2. ```yaml
  3. # yaml表示以上对象
  4. person:
  5. userName: "张三"
  6. # userName: zhangsan
  7. boss: false
  8. birth: "2021/5/16 22:15:29"
  9. age: 18
  10. pet:
  11. name: tomcat
  12. weight: 23.4
  13. interests: [ 篮球, 游泳 ]
  14. animal:
  15. - tomcat
  16. - timi
  17. score:
  18. history: 88
  19. english:
  20. first: 30
  21. second: 40
  22. third: 50
  23. math: [ 131,140,148 ]
  24. chinese: { first: 128,second: 136 }
  25. salarys: [ 3999,4999.98,5999.99 ]
  26. allPets:
  27. sick:
  28. - { name: tom }
  29. - { name: jerry,weight: 47 }
  30. health: [ { name: mario,weight: 47 } ]
  • 编写测试接口

    1. @RestController
    2. public class PersonController {
    3. @Autowired
    4. private Person person;
    5. @GetMapping("/person")
    6. public Person person() {
    7. return person;
    8. }
    9. }

    访问 localhost:8080/person,发现配置信息未能绑定成功。原因:未将其组件注册。

  • Person 类上添加注解:@ConfigurationProperties(prefix = “person”)

  • 配置类上添加 @EnableConfigurationProperties({ … , Person**.**class})

再次访问测试接口,参数绑定正常。
image.png

2、配置提示

自定义的类和配置文件绑定一般没有提示,引入以下依赖。

  1. <!-- 提示自定义的类和配置文件绑定 -->
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-configuration-processor</artifactId>
  5. <optional>true</optional>
  6. </dependency>
  7. <build>
  8. <plugins>
  9. <plugin>
  10. <groupId>org.springframework.boot</groupId>
  11. <artifactId>spring-boot-maven-plugin</artifactId>
  12. <configuration>
  13. <excludes>
  14. <exclude>
  15. <groupId>org.projectlombok</groupId>
  16. <artifactId>lombok</artifactId>
  17. </exclude>
  18. <!-- 编译的时候不将其打入包中 -->
  19. <exclude>
  20. <groupId>org.springframework.boot</groupId>
  21. <artifactId>spring-boot-configuration-processor</artifactId>
  22. </exclude>
  23. </excludes>
  24. </configuration>
  25. </plugin>
  26. </plugins>
  27. </build>