共计 4505 个字符,预计需要花费 12 分钟才能阅读完成。
配置文件详解
SpringBoot 的全局配置文件有两种:
- application.properties
- application.yml
配置文件的作用:修改 SpringBoot 自动配置的默认值.
properties 配置文件我们之前都有接触,今天就让我们来认识一下 yaml 配置文件吧。
YAML 表示 YAML Ain’t Markup Language,在百度百科的解释是:
YAML 是 ”YAML Ain’t a Markup Language”(YAML 不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:”Yet Another Markup Language”(仍是一种标记语言),但为了强调这种语言以数据做为中心,而不是以标记语言为重点,而用反向缩略语重命名。
所以,我们不用在意它是否是一种标记语言,我们只要记得它是一种以数据为中心的语言就可以,语法非常简洁,使用空白,缩进,分行组织数据,从而使得表示更加简洁易读。
YAML 基本语法
- 大小写敏感
- 使用缩进表示层级关系
- 缩进时不允许使用 Tab 键,只允许使用空格。
- 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
所以 YAML 基本语法其实就是 key:(空格)value 的形式,其中空格必须要有,以空格的缩进来控制层级关系,只要对齐的一列数据都是同一个层级的,比如:
server:
port: 8081
path: /example
YAML 支持的数据结构
字面量(也有“纯量”一叫法)
语法:
字面量:普通的值(整数、浮点数、字符串、布尔、Null 值、时间、日期)
- key: value(字面值直接写上就可以)
- 字符串也默认不需要加上单引号和双引号的(也可以加上引号)
- 单引号:会转义特殊字符,将特殊字符转为一个普通的字符串
- name: ‘xiaowang \n’ 打印 xiaowang \n (ps: 这里的 \n 被转成字符串)
- 双引号:不会转义特殊字符,特殊字符还是表达其本身想表示的意思
- name: ‘xiaowang \n’ 打印 xiaowang 换行 (ps: 这里的 \n 执行换行操作)
示例:
name: 张三
boolean: TRUE #true,True 都可以
float:
- 3.14
- 6.8523015e+5 #可以使用科学计数法
int:
- 123
- 0b1010\_0111\_0100\_1010\_1110 #二进制表示
null:
nodeName: 'node'
parent: ~ #使用~ 表示 null
string:
- 哈哈
- 'Hello world' #可以使用双引号或者单引号包裹特殊字符
- newline
newline2 #字符串可以拆成多行,每一行会被转化成一个空格
date:
- 2018-02-17 #日期必须使用 ISO 8601 格式,即 yyyy-MM-dd
** 注意 **:在 springboot 中 yaml 文件的时间格式 date: yyyy/MM/dd HH:mm:ss
对象
- 对象:也可以说是 map,也就是键值对的形式
- key: value 形式(对象属性 key: value 的形式表示,在对象名下一行写属性: 属性值)
- 同一个对象的各个属性前对齐就可以(默认是两个空格)
示例:
user:
username: root
password: rootpwd
- 另外对象也可以写成行内形式
例如:
user:{username: root,password: rootpwd}
数组
数组:也可以说是 list 或者序列的方式表示 用 ”-“ 空格 值的方式表示数组中一个元素
示例:
pets:
- cat
- dog
同样数组也有对应的行内写法,如:
pets: \[cat,dog\]
注意:在实际应用中经常是多种类型相互配合、相互嵌套配合使用,下面我们就来上一个实例
注释
“#”被注释内容
文本块
|:使用 |
标注的文本内容缩进表示的块,可以保留块中已有的回车换行
value: |
hello
world!
# 输出结果:hello 换行 world!
+
表示保留文字块末尾的换行,-
表示删除字符串末尾的换行。
value: |
hello
value: |\-
hello
value: |+
hello
\# 输出:hello\\n hello hello\\n\\n(有多少个回车就有多少个 \\n)
注意“|”与 文本之间须另起一行
>:使用 >
标注的文本内容缩进表示的块,将块中回车替换为空格,最终连接成一行
value: > hello
world!
\# 输出:hello 空格 world!
YAML 在项目中的实际应用
开始实践,yaml 使用的时候,经常是组合写法的,也就是对象、字面值等等一起组合使用的,本文结合 Springboot,介绍一下这种用法,在 Springboot 中,yaml 语言被用于配置属性,这种写法很简洁,值得推广
- 在 Springboot 项目的
resources 目录
中添加application.yml
文件,注意文件名字不能写错,后缀可以使 yaml 或者 yml 都可以,该配置文件 springboot 项目启动的时候会自动加载
内容如下:
\## 测试 ConfigurationProperties
user:
userName: root
isAdmin: true
regTime: 2020/01/01
isOnline: 1
maps: {k1 : v1,k2: v2}
lists:
- list1
- list2
address:
tel: 15899988899
name: 上海市
2. 编写测试 bean 类进行映射
2.1 User 类
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
import java.util.Date;
import java.util.List;
import java.util.Map;
@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;}
}
解释:
@Component
需要将配置文件中每个属性都映射到这个组件,注意:记得加 @Component 注解,这样才能将这个组件加载到 Spring 容器中
@ConfigurationProperties(prefix = “user”)
通过 prefix 属性配置的 user 在配置文件中绑定 user 对象,将配置文件中的属性值直接映射到 bean 属性中
2.2 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;}
}
3. 测试
ok,这时候启动项目的时候就可在容器中直接使用 user 对象了,现在我们使用 spirng 自带的测试类,测试一下
import com.example.easy.entity.Stu;
import org.junit.jupiter.api.Test;
importorg.springframework.boot.test.context.SpringBootTest;
import javax.annotation.Resource;
@SpringBootTest
class EasyApplicationTests {
@Autowired
User user;
@Test
public void testConfigurationProperties(){System.out.println(user);
}
}
说明:
使用
@Autowired
装配 bean 直接输出节课(也可以使用其他的注解进行装配)
- 运行效果
User{userName='root', isAdmin=false, regTime=Wed Jan 01 00:00:00 CST 2020, isOnline=1, maps={k1=v1, k2=v2}, lists=[list1, list2], address=Address{tel='15899988899', name='上海市'}}