SpringBoot配置文件

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 数据类型

  • 字面量:单个的、不可再分的值。data、boolen、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 示例

@Component
@ConfigurationProperties(prefix = "person")
@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;
}
person:
  userName: "zhangsan \n 李四"
  boss: false
  birth: 2000/4/2
  age: 18
  pet:
    name: cat
    weight: 23.4
  interests: [篮球,游泳]
  animal:
    - jerry
    - mario
  score:
    englishi:
      first: 30
      second: 50
      third: 40
    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}]

其中,在yml中,单引号会把\n作为字符串输出,双引号将\n作为换行输出。

双引号不会转义,单引号会转义。

即双引号转义字符生效,单引号转义字符失效。

2. 配置提示

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

官方文档给了解决方案

导入对应的依赖
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-configuration-processor</artifactId>
    <optional>true</optional>
</dependency>

打包时不打该依赖,防止打出的包过大,或者在jvm中运行时过大
    <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>
posted @ 2022-06-22 10:01  洛沐辰  阅读(54)  评论(0编辑  收藏  举报