YAML語法:
命名
YAML是"YAML Ain't a Markup Language"(YAML不是一種置標語言)的遞迴縮寫。 在開發的這種語言時,YAML 的意思其實是:"Yet Another Markup Language"(仍是一種置標語言),
YAML是YAML不是一種標記語言的外語縮寫;但為了強調這種語言以資料做為中心,而不是以置標語言為重點,而用返璞詞重新命名。它是一種直觀的能夠被電腦識別的資料序列化格式,是一個可讀性高並且容易被人類閱讀,容易和指令碼語言互動,用來表達資料序列的程式語言。
標記語言:以前的配置檔案;大多都使用的是 xxxx.xml檔案;
YAML:以資料為中心,比json、xml等更適合做配置檔案;
YAML:配置例子
server:
port: 8081
複製程式碼
相當於XML:
<server>
<port>8080</port>
</server>
複製程式碼
基本語法 k:(空格)v:表示一對鍵值對(空格必須有); 以空格的縮排來控制層級關係;只要是左對齊的一列資料,都是同一個層級的
server:
### 值的寫法
port: 8080
path: /hello
複製程式碼
屬性和值也是大小寫敏感;
值的寫法
字面量:普通的值(數字,字串,布林)
k: v:字面直接來寫;
字串預設不用加上單引號或者雙引號;
"":雙引號;不會轉義字串裡面的特殊字元;特殊字元會作為本身想表示的意思
name:"HOWD \n lisi":輸出;HOWD 換行 lisi
'':單引號;會轉義特殊字元,特殊字元最終只是一個普通的字串資料
name: ‘HOWD \n lisi’:輸出;HOWD \n lisi
物件、Map(屬性和值)(鍵值對):
k: v:在下一行來寫物件的屬性和值的關係;注意縮排
物件還是k: v的方式
friends:
lastName: HOWD
age: 21
複製程式碼
行內寫法:
friends: {lastName: HOWD,age: 21}
複製程式碼
陣列(List、Set):
用- 值表示陣列中的一個元素
pets:
- cat
- dog
- pig
複製程式碼
行內寫法
pets: [cat,dog,pig]
複製程式碼
配置檔案值注入
配置檔案 application.yml
person:
lastName: hello
age: 20
boss: true
birth: 2018/09/28
maps: {k1: v1,k2: 12}
lists:
- bin
- zhaoliu
dog:
name: dog
age: 12
複製程式碼
javaBean:
/**
* 將配置檔案中配置的每一個屬性的值,對映到這個元件中
* @ConfigurationProperties:告訴SpringBoot將本類中的所有屬性和配置檔案中相關的配置進行繫結;
* prefix = "person":配置檔案中哪個下面的所有屬性進行一一對映
*
* 只有這個元件是容器中的元件,才能給容器提供的@ConfigurationProperties功能;
*
*/
@Component
@ConfigurationProperties(prefix = "person")
public class Person {
private String lastName;
private Integer age;
private Map<String,Object> maps;
private List<Object> lists;
private Dog dog;
複製程式碼
我在上一篇properties中有有說到當你是使用使用 @ConfigurationProperties 註解在idea會給我們提示,需要匯入配置檔案處理器。
在pom匯入配置檔案處理器,以後編寫配置就有提示了:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
複製程式碼
properties配置檔案在idea中預設utf-8可能會亂碼
@Value獲取值和@ConfigurationProperties獲取值比較
@Value是以前spring底層的,使用@Value需要一個一個引數指定,@ConfigurationProperties批量注入配置檔案中的屬性。更多比較如下:
班級 | @ConfigurationProperties | @Value |
---|---|---|
功能 | 批量注入配置檔案中的屬性 | 一個個指定 |
鬆散繫結(鬆散語法) | 支援 | 不支援 |
SpEL | 不支援 | 支援 |
JSR303資料校驗 | 支援 | 不支援 |
複雜型別封裝 | 支援 | 不支援 |
配置檔案yml還是properties他們都能獲取到值;
如果說,我們只是在某個業務邏輯中需要獲取一下配置檔案中的某項值,使用@Value;
如果說,我們專門編寫了一個javaBean來和配置檔案進行對映,我們就直接使用@ConfigurationProperties;
配置檔案注入值資料校驗
@Validated
@ConfigurationProperties支援JSR303資料校驗,@Value不支援JSR303資料校驗。
@Component
@ConfigurationProperties(prefix = "person")
@Validated
public class Person {
/**
* <bean class="Person">
* <property name="lastName" value="字面量/${key}從環境變數、配置檔案中獲取值/#{SpEL}"></property>
* <bean/>
*/
//lastName必須是郵箱格式
// @Email
//@Value("${person.last-name}")
private String lastName;
//@Value("#{11*2}")
private Integer age;
//@Value("true")
private Boolean boss;
}
複製程式碼
@PropertySource&@ImportResource&@Bean
@PropertySource:載入指定的配置檔案;
person.properties
person.last-name=hfbin
person.age=23
person.boss=true
複製程式碼
Person.java
@PropertySource(value = {"classpath:person.properties"})
@Component
@ConfigurationProperties(prefix = "person")
public class Person {
private String lastName;
private Integer age;
private Boolean boss;
}
複製程式碼
@ImportResource:匯入Spring的配置檔案,讓配置檔案裡面的內容生效;
Spring Boot裡面沒有Spring的配置檔案,我們自己編寫的配置檔案,也不能自動識別;
想讓Spring的配置檔案生效;
@ImportResource(locations = {"classpath:beans.xml"})
匯入Spring的配置檔案讓其生效
複製程式碼
再來編寫Spring的配置檔案
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="helloService" class="cn.hfbin.demo01.service.HelloService"></bean>
</beans>
複製程式碼
SpringBoot推薦給容器中新增元件的方式;推薦使用全註解的方式
1、配置類 @Configuration ------>Spring配置檔案
2、使用 @Bean 給容器中新增元件
/**
* @Configuration:指明當前類是一個配置類;就是來替代之前的Spring配置檔案
*
* 在配置檔案中用<bean><bean/>標籤新增元件
*
*/
@Configuration
public class MyAppConfig {
//將方法的返回值新增到容器中;容器中這個元件預設的id就是方法名
@Bean
public HelloService helloService02(){
System.out.println("配置類@Bean給容器中新增元件了...");
return new HelloService();
}
}
複製程式碼
感謝你花時間讀到結尾!:D
後端一枚,默默搬磚擼程式碼,如果覺得不錯歡迎關注我的公眾號