Spring Boot yaml 配置文件

配置文件

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

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

application.yaml

person:
  userName: '阿颜 \n 阿云'
# 单引号会将 \n作为字符串输出  双引号会将\n作为换行输出
  boss: true
  birth: 1997/06/27
  age: 24
#  interests: [篮球,乒乓球]
  interests:
    - 篮球
    - 足球
    - 乒乓球
  animal: [阿猫,阿狗]
#  score:
#    english: 80
#    math: 90
  score: {
    
    english:80,math:90}
  salarys:
    - 3333.33
    - 4444.44
  pet:
    name: 阿狗
    weight: 99.99
  allPets:
    sick:
      - {
    
     name: tom }
      - {
    
     name: agou,weight: 47 }
    health: [ {
    
     name: maria,weight: 47 } ]
@RestController
public class HelloController {
    
    

    @Autowired
    Person person;

    @RequestMapping("/person")
    public Person person() {
    
    

        String userName = person.getUserName();
        System.out.println(userName);
        return person;
    }
}

在这里插入图片描述

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>

猜你喜欢

转载自blog.csdn.net/weixin_51600120/article/details/114437019