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

    行内写法:  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、示例

    ```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; }


```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}]

image.png
如果同时有这两个配置文件,那么都会生效(springboot会把他们的内容合在一起生效)

2. 通过yaml配置文件为 实体类属性赋值

04、配置文件  --YAML格式 - 图204、配置文件  --YAML格式 - 图3

2.1 String、Boolean、Date、Integer等赋值规则一样,都是直接写就行了

大写字母:比如userName 可以写成 user-name

04、配置文件  --YAML格式 - 图4

2.2 String[]、list、set赋值规则一样:共有两种规则

为什么他三个一样:list可以看成容量不定的数组,而set又和list同是Collection的子类

2.2.1 用 []包围

04、配置文件  --YAML格式 - 图5

2.2.2 用 -

特殊:如果是没有 -, 其实是一个对象

04、配置文件  --YAML格式 - 图6

2.2.3 其他写法

04、配置文件  --YAML格式 - 图7

2.3 Map、对象 的赋值规则:中间是逗号

为什么他们两个一样:因为都是 K-V的形式。 不能接受中文,如果是中文,和没写一样

2.3.1 Map和对象一样都是用{}包围

对象:
04、配置文件  --YAML格式 - 图8
map:
04、配置文件  --YAML格式 - 图9
04、配置文件  --YAML格式 - 图10

2.3.2 也可以用换行(注意没有 -形式)

对象:
04、配置文件  --YAML格式 - 图11
map:
04、配置文件  --YAML格式 - 图1204、配置文件  --YAML格式 - 图13

2.3.3 一些不合规范的写法

{} 里的属性没有空格、换行加 - 、换行没有空格(通不过编译)

04、配置文件  --YAML格式 - 图14
04、配置文件  --YAML格式 - 图15
04、配置文件  --YAML格式 - 图16
04、配置文件  --YAML格式 - 图17
04、配置文件  --YAML格式 - 图18
04、配置文件  --YAML格式 - 图19

2.3.4 复杂类型

04、配置文件  --YAML格式 - 图2004、配置文件  --YAML格式 - 图21

2.3.5 单引号、双引号

双引号不转义(不改变原有内容里转义的字符的含义)
04、配置文件  --YAML格式 - 图2204、配置文件  --YAML格式 - 图23
单引号转义(改变原有内容里转义字符的含义):比如把 \n改成字符串
04、配置文件  --YAML格式 - 图2404、配置文件  --YAML格式 - 图25

3. 配置提示

自定义的类和配置文件绑定一般没有提示。想要提示,需要加上processor依赖。
下面build的存在是为了在打jar包时排除processor包,毕竟只有编译的时候才用的到(用来提示),所以完全没有必要打到jar包里增加运行jar包的启动时间