SpringBoot —— 4、配置文件

目录

1、文件类型

1.1、properties

1.2、yaml

1.2.1、简介

1.2.2、基本语法

1.2.3、数据类型

1.2.4、示例

2、配置提示


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

String 类型可以使用单引号或双引号表示
# 单引号会将 \n 作为字符串输出,双引号会将 \n 作为换行输出
# 单引号不会使转义字符生效,双引号会使转义字符生效 

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

① 引入lombok依赖,创建两个类

@Component
@ConfigurationProperties(prefix = "person")
@Data
@ToString
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
@ToString
public class Pet {
    private String name;
    private Double weight;
}

② 创建 yaml 的配置文件,application.yaml,后缀也可以是 yml

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

2、配置提示

自定义的类和配置文件绑定一般没有提示。且会提示未配置 SpringBoot 配置注解处理器

 这时只需添加依赖

		<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/Mr_zhangyj/article/details/123887000