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. person:
  2. userName: "manster \n manster" #转义
  3. Person(userName=manster
  4. manster, boss=true, birth=
  5. person:
  6. userName: 'manster \n manster'
  7. Person(userName=manster \n manster, boss=true, birth

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、示例

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

person:
  userName: manster
  boss: true
  birth: 2021/1/26
  age: 18
  pet:
    name: tomcat
    weight: 20.3
  #interests: [篮球,足球]
  interests:
    - 篮球
    - 足球
    - 18
  animal: [猫,狗]
  #score: {english:80,math:90}
  score:
    english: 80
    math: 90
  #salarys: [8000,9999]
  salarys:
    - 8000
    - 9000
  allPets:
    sick:
      - {name: 狗,weight: 30.3}
      - name: 猫
        weight: 23.3
      - name: 羊驼
        weight: 150
    health: [{name: 兔,weight: 10.3},{name: 猪,weight: 200}]

一定要注意在 : 后面的值要空一个格再写

controller

@RestController
public class HelloController {

    @Autowired
    private Person person;

    @GetMapping("/person")
    public Person person(){
        return  person;
    }

}
{
    "userName": "manster",
    "boss": true,
    "birth": "2021-01-25T16:00:00.000+00:00",
    "age": 18,
    "pet": {
        "name": "tomcat",
        "weight": 20.3
    },
    "interests": [
        "篮球",
        "足球",
        "18"
    ],
    "animal": [
        "猫",
        "狗"
    ],
    "score": {
        "english": 80,
        "math": 90
    },
    "salarys": [
        8000.0,
        9000.0
    ],
    "allPets": {
        "sick": [
            {
                "name": "狗",
                "weight": 30.3
            },
            {
                "name": "猫",
                "weight": 23.3
            },
            {
                "name": "羊驼",
                "weight": 150.0
            }
        ],
        "health": [
            {
                "name": "兔",
                "weight": 10.3
            },
            {
                "name": "猪",
                "weight": 200.0
            }
        ]
    }
}

2、配置提示

自定义的类和配置文件绑定一般没有提示。

        <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>
                        <groupId>org.springframework.boot</groupId>
                        <artifactId>spring-boot-configuration-processor</artifactId>
                    </exclude>
                </excludes>
            </configuration>
        </plugin>
    </plugins>
</build>