SpringBoot系列之YAML配置用法學習筆記

一、全局配置

SpringBoot的全局配置文件有兩種:html

  • application.properties
  • application.yml

配置文件的做用:修改SpringBoot自動配置的默認值,主要是默認值,由於SpringBoot啓動時會自動加載不少默認配置,詳細的能夠參考我以前博客源碼學習系列之SpringBoot自動配置java

二、YAML語言定義

YAML表示YAML Ain’t Markup Language,在百度百科的解釋是:spring

YAML是"YAML Ain't a Markup Language"(YAML不是一種標記語言)的遞歸縮寫。在開發的這種語言時,YAML 的意思實際上是:"Yet Another Markup Language"(還是一種標記語言),但爲了強調這種語言以數據作爲中心,而不是以標記語言爲重點,而用反向縮略語重命名。json

因此,咱們不用在乎它是不是一種標記語言,咱們只要記得它是一種以數據爲中心的語言就能夠,語法很是簡潔,使用空白,縮進,分行組織數據,從而使得表示更加簡潔易讀。數組

三、YAML基本語法

引用博客http://www.ruanyifeng.com/blog/2016/07/yaml.html數據結構

  • 大小寫敏感
  • 使用縮進表示層級關係
  • 縮進時不容許使用Tab鍵,只容許使用空格。
  • 縮進的空格數目不重要,只要相同層級的元素左側對齊便可

因此YAML基本語法其實就是key:(空格)value的形式,其中空格必需要有,以空格的縮進來控制層級關係,只要對齊的一列數據都是同一個層級的,好比:app

server:
  port: 8081
  path: /example

注意:屬性key和值都是大小寫敏感的ide

四、YAML支持的數據結構

  • 字面量:普通的值(整數、浮點數、字符串、布爾、Null值、時間、日期)
    key: value(字面值直接寫上就能夠)
      字符串也默認不須要加上單引號和雙引號的
      單引號:會轉義特殊字符,將特殊字符轉爲一個普通的字符串
      name: 'xiaowang \n' 打印 xiaowang \n (ps:這裏的\n被轉成字符串)
      雙引號:不會轉義特殊字符,特殊字符仍是表達其自己想表示的意思
      name: 'xiaowang \n' 打印 xiaowang 換行 (ps:這裏的\n執行換行操做)spring-boot

  • 對象:也能夠說是map,也就是鍵值對的形式
    key: value(以對象屬性key:value的形式表示,在對象名下一行寫屬性:屬性值,,一樣注意空格縮進)
    example:單元測試

user:
  username: root
  password: rootpwd

也能夠用行內寫法表示:

user:{username: root,password: rootpwd}
  • 數組:也能夠說是list或者序列的方式表示
    用"-"符合+值的方式數組中一個元素
pets:
  - cat
  - dog

顯然也有行內寫法,用[]中括號表示

pets: [cat,dog]

五、例子實踐

ok,上面的都是一些必要的理論,下面開始實踐,yaml使用的時候,常常是組合寫法的,也就是對象、字面值等等一塊兒組合使用的,本文結合Springboot,介紹一下這種用法,在Springboot中,yaml語言被用於配置屬性,這種寫法很簡潔,值得推廣

在Springboot的application.yml文件加上以下配置:

## 測試ConfigurationProperties
user:
  userName: root
  isAdmin: true
  regTime: 2019/11/01
  isOnline: 1
  maps: {k1 : v1,k2: v2}
  lists:
   - list1
   - list2
  address:
    tel: 15899988899
    name: 上海市

編寫測試bean類進行映射

import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

import java.util.Date;
import java.util.List;
import java.util.Map;


/**
 * <pre>
 *  將配置文件中每一個屬性都映射到這個組件,注意:記得加@Component註解,這樣才能將這個組件     *   加載到Spring容器中
 * </pre>
 */
@Component
@ConfigurationProperties(prefix = "user")
public class User {

    private String userName;
    private boolean isAdmin;
    private Date regTime;
    private Long isOnline;
    private Map<String,Object> maps;
    private List<Object> lists;
    private Address address;

    @Override
    public String toString() {
        return "User{" +
                       "userName='" + userName + '\'' +
                       ", isAdmin=" + isAdmin +
                       ", regTime=" + regTime +
                       ", isOnline=" + isOnline +
                       ", maps=" + maps +
                       ", lists=" + lists +
                       ", address=" + address +
                       '}';
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public boolean isAdmin() {
        return isAdmin;
    }

    public void setAdmin(boolean admin) {
        isAdmin = admin;
    }

    public Date getRegTime() {
        return regTime;
    }

    public void setRegTime(Date regTime) {
        this.regTime = regTime;
    }

    public Long getIsOnline() {
        return isOnline;
    }

    public void setIsOnline(Long isOnline) {
        this.isOnline = isOnline;
    }

    public Map<String, Object> getMaps() {
        return maps;
    }

    public void setMaps(Map<String, Object> maps) {
        this.maps = maps;
    }

    public List<Object> getLists() {
        return lists;
    }

    public void setLists(List<Object> lists) {
        this.lists = lists;
    }

    public Address getAddress() {
        return address;
    }

    public void setAddress(Address address) {
        this.address = address;
    }
}

Address類:

public class Address {
    private String tel;
    private String name;

    @Override
    public String toString() {
        return "Address{" +
                       "tel='" + tel + '\'' +
                       ", name='" + name + '\'' +
                       '}';
    }

    public String getTel() {
        return tel;
    }

    public void setTel(String tel) {
        this.tel = tel;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

寫個junit測試類來單元測試:

import org.junit.Test;
import org.junit.runner.RunWith;
import org.muses.jeeplatform.bean.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.junit4.SpringRunner;

@RunWith(SpringRunner.class)
@org.springframework.boot.test.context.SpringBootTest
public class SpringBootTest {

    @Autowired
    User user;

    @Test
    public void testConfigurationProperties(){
        System.out.println(user);
    }

}
User{userName='root', isAdmin=false, regTime=Fri Nov 01 00:00:00 CST 2019, isOnline=1, maps={k1=v1, k2=v2}, lists=[list1, list2], address=Address{tel='15899988899', name='上海市'}}

測試經過後,idea會提示,
https://docs.spring.io/spring-boot/docs/1.5.7.RELEASE/reference/html/configuration-metadata.html#configuration-metadata-annotation-processor

在這裏插入圖片描述

而後,咱們加上pom配置就能夠

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>
相關文章
相關標籤/搜索