SpringBoot——聊聊application.properties和application.yml的写法规范及区别

简介: SpringBoot——聊聊application.properties和application.yml的写法规范及区别

1.写在前面


我们都知道SpringBoot项目都有一个核心配置文件叫 application.xxx,这个xxx后缀名可以有三种类型:propertiesymlyaml,这里可能我理解的不太精确,我认为 yml yaml 没什么区别。


YAML "YAML Ain't Markup Language"YAML 不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:"Yet Another Markup Language"(仍是一种标记语言)。非常适合用来做以数据为中心的配置文件。


properties就不用多说了,之前都经常写,就是这种 a.b.c=xxx 形式。


如果转换成 yml,就需要写成:

a

 b

   cxxx 这种形式。它也有一定的基本语法:

·       key: valuekv之间有空格

·       大小写敏感

·       使用缩进表示层级关系

·       缩进不允许使用tab,只允许空格(在IDEA中只所以 tab 没问题,是因为IDEA自动将 tab 转为了4个空格)

·       缩进的空格数不重要,只要相同层级的元素左对齐即可

·       '#' 表示注释

·       字符串无需加引号,如果要加,''""表示字符串内容会被转义/不转义

·      


字面量:单个的、不可再分的值。datebooleanstringnumbernull

k: v

·       对象:键值对的集合。maphashsetobject

行内写法:  k: {k1:v1,k2:v2,k3:v3}
#或
k: 
  k1: v1
  k2: v2
  k3: v3

·       数组:一组按次序排列的值。arraylistqueue

行内写法:  k: [v1,v2,v3]
#或者
k:
 - v1
 - v2
 - v3

下面,通过一个案例,来分别演示一下 properties yml 的写法。

2.项目源码


首先,这是一个 springboot web项目,依赖如下:👇👇👇

分别添加的 web 项目起步依赖、lombok简化开发。

我们在之前配置文件中写 spring.application.namespring.datasource.url 这些官方的配置都有提示,但是自定义的类和配置文件绑定一般没有提示。要有提示可以添加 pom 文件中的最后一个依赖以及build中的插件即可。

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>
    </dependencies>
    <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>

下面我们写两个实体Bean,其中有各自的属性信息。

Person类中 @Data 自动生成getter/settertoStringhashCodeequals等等这些方法,@Component将其添加到IoC容器中,@ConfigurationProperties将与配置文件完成属性前缀为 person 的绑定。

package com.szh.boot.bean;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
 *
 */
@Data
@Component
@ConfigurationProperties(prefix = "person")
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> salary;
    private Map<String, List<Pet>> allPets;
}
package com.szh.boot.bean;
import lombok.Data;
/**
 *
 */
@Data
public class Pet {
    private String name;
    private Double weight;
}

然后再写一个controller

package com.szh.boot.controller;
import com.szh.boot.bean.Person;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
/**
 *
 */
@RestController
@Slf4j
public class TestController {
    @Autowired
    private Person person;
    @GetMapping(value = "/getInfo")
    public Person getInfo() {
        return person;
    }
}

项目启动类的代码我就不贴了,下面给出 propertiesyml 两种配置文件的写法。


2.1 properties

person.user-name=张起灵
person.boss=true
person.birth=2020/09/10 13:14:15
person.age=18
person.pet.name=金毛犬
person.pet.weight=13.14
person.interests=[篮球,足球,排球]
person.animal[0]=Dog
person.animal[1]=Pig
person.animal[2]=Cat
person.score.Chinese[0]=98
person.score.Chinese[1]=99
person.score.Chinese[2]=100
person.score.Math.first=60
person.score.Math.second=65
person.score.Math.third=70
person.score.English.do=11
person.score.English.does=22
person.score.English.did=33
person.score.History[0]=Han Dynasty
person.score.History[1]=Tang Dynasty
person.score.History[2]=Qing Dynasty
person.salary[0]=5555
person.salary[1]=6666
person.salary[2]=7777
person.all-pets.sick[0].name=牧羊犬
person.all-pets.sick[0].weight=20.5
person.all-pets.sick[1].name=导盲犬
person.all-pets.sick[1].weight=18.1
person.all-pets.health[0].name=藏獒
person.all-pets.health[0].weight=44.4
person.all-pets.health[1].name=萨摩耶
person.all-pets.health[1].weight=28.5

不得不说,我写了那么久的 proeprties,一直觉得这种格式挺舒服的,但是这次我错了,必须承认 yml 要强于 properties 了。


2.2 yml

person:
  user-name: 张起灵
  boss: true
  birth: 2020/09/10 13:14:15
  age: 18
  pet:
    name: 金毛犬
    weight: 13.14
  interests: [篮球,足球,排球]
  animal:
    - Dog
    - Pig
    - Cat
  score:
    Chinese: [98,99,100]
    Math:
      first: 60
      second: 65
      third: 70
    English: {do: 11, does: 22, did: 33}
    History:
      - Han Dynasty
      - Tang Dynasty
      - Qing Dynasty
  salary: [5555,6666,7777]
  all-pets:
    sick:
      - {name: 牧羊犬, weight: 20.5}
      - {name: 导盲犬, weight: 18.1}
    health: [{name: 藏獒, weight: 44.4},{name: 萨摩耶, weight: 28.5}]

对比两种形式,明显感觉到 yml 整体看起来要比 properties 舒服多了。

下面启动项目测试一下。

相关文章
|
6天前
|
Java API 微服务
【Spring Boot系列】通过OpenAPI规范构建微服务服务接口
【4月更文挑战第5天】通过OpenAPI接口构建Spring Boot服务RestAPI接口
|
1月前
|
JSON Java API
Springboot项目中如何设计一个规范的统一的Restful API 响应框架?
Springboot项目中如何设计一个规范的统一的Restful API 响应框架?
23 1
|
4月前
|
前端开发 NoSQL Java
SpringBoot中application.properties的常用配置
SpringBoot中application.properties的常用配置
|
4月前
|
Java
application.properties模板+application.yml模板+pom模板+mapper.xml模板(springboot)
application.properties模板+application.yml模板+pom模板+mapper.xml模板(springboot)
36 0
|
8月前
|
Java Spring
Java——spring boot打的jar包如何引用外部application.properties
Java——spring boot打的jar包如何引用外部application.properties
|
8月前
|
前端开发 新制造 UED
SpringBoot-23-全局异常机制+RESTful统一规范
SpringBoot-23-全局异常机制+RESTful统一规范
85 0
|
8月前
|
XML 网络架构 数据格式
SpringBoot-22-RESTful统一规范响应数据格式
REST是Representational State Transfer的缩写,是在2000年被Roy Thomas Fielding提出的,Fielding是一个很厉害的人物,他是HTTP协议的主要设计者。REST是他对互联网软件构架的原则。REST是一种针对网络应用设计和软件开发方式,降低了开发的复杂性,提高了系统的可伸缩性。如果想要具体了解一下其含义可以查看一下阮一峰老师对REST理解RESTful架构。
72 0
|
11月前
|
前端开发 Java API
SpringBoot 常用的配置文件 application.yml和 bootstrap.yml的区别
SpringBoot默认支持properties和YAML两种格式的配置文件。前者格式简单,但是只支持键值对。如果需要表达列表,最好使用YAML格式。SpringBoot支持自动加载约定名称的配置文件,例如application.yml。如果是自定义名称的配置文件,就要另找方法了。可惜的是,不像前者有@PropertySource这样方便的加载方式,后者的加载必须借助编码逻辑来实现。
344 0
|
Java
SpringBoot获得application.yml中数据的几种方式
SpringBoot获得application.yml中数据的几种方式
129 0
|
XML 前端开发 Java