SpringBoot的全局配置文件有兩種:html
配置文件的做用:修改SpringBoot自動配置的默認值,主要是默認值,由於SpringBoot啓動時會自動加載不少默認配置,詳細的能夠參考我以前博客源碼學習系列之SpringBoot自動配置java
YAML表示YAML Ain’t Markup Language,在百度百科的解釋是:spring
YAML是"YAML Ain't a Markup Language"(YAML不是一種標記語言)的遞歸縮寫。在開發的這種語言時,YAML 的意思實際上是:"Yet Another Markup Language"(還是一種標記語言),但爲了強調這種語言以數據作爲中心,而不是以標記語言爲重點,而用反向縮略語重命名。json
因此,咱們不用在乎它是不是一種標記語言,咱們只要記得它是一種以數據爲中心的語言就能夠,語法很是簡潔,使用空白,縮進,分行組織數據,從而使得表示更加簡潔易讀。數組
引用博客http://www.ruanyifeng.com/blog/2016/07/yaml.html數據結構
- 大小寫敏感
- 使用縮進表示層級關係
- 縮進時不容許使用Tab鍵,只容許使用空格。
- 縮進的空格數目不重要,只要相同層級的元素左側對齊便可
因此YAML基本語法其實就是key:(空格)value的形式,其中空格必需要有,以空格的縮進來控制層級關係,只要對齊的一列數據都是同一個層級的,好比:app
server: port: 8081 path: /example
注意:屬性key和值都是大小寫敏感的ide
字面量:普通的值(整數、浮點數、字符串、布爾、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}
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>