SpringBoot使用一个全局的配置文件,配置文件名是固定的;
1. application.properties
2.application.yml
yml:
YAML(YAML Ain’t Markup Language)
YAML A Markup Language:是一个标记语言
YAML isn’t Markup Language:不是一个标记语言;
标记语言:
以前的配置文件;大多都使用的是 xxxx.xml文件
YAML:以数据为中心,比json、xml等更适合做配置文件;
YAML:配置例子
server:
port: 8081
XML:配置例子
<server>
<port>8081</port>
</server>
YAML语法
1. 基本语法
K: (空格)V:表示一对键值对(空格必须有);
以空格的缩进来控制层级关系;只有是左对齐的一列数据,都是同一个层级的
server:
port: 8081
path: /hello
属性和值也是大小写敏感的;
2.值的写法
2.1.字面量普通的值(数字,字符串,布尔)
K: V:字面直接来写;
字符串默认不用加上单引号,或者双引号;
“”:双引号:会转义字符串里面的特殊字符;特殊字符会作为本身想表示的意思
name: “zhangsan \n lisi”:输出:zhangsan 换行 lisi
’‘:单引号:不会转义特殊字符,特殊字符最终只是一个普通的字符串输出
name: “zhangsan \n lisi”:输出:zhangsan /n lisi
2.2对象、Map(属性和值)(键值对):
K: V :在下一行来写对象的属性和值的关系:注意缩进
对象还是k: v的方式
friends:
lastName:zhangsan
age:20
写法二:行内写法:
friends:{lastName: zhangsan,age: 18}
**注意是{K:(空格)V}**
3. 数组,集合(List,Set)
用 - 值表示数组中的一个元素
pets:
- cat
- dog
- pig
行内写法:
pets: [cat,dog,pig]
3、配置文件值注入
3.1配置文件(application.yml)
server:
port: 8081
person:
lastName: zhangsan
age: 18
boos: true
brith: 2017/12/12
maps: {k1: v1,k2: 12}
lists:
- lisi
- zhaoliu
dog:
name: erha
age: 5
javaBean:
@Component
@ConfigurationProperties(prefix = "person")
public class Person {
private String lastName;
private Integer age;
private Boolean boos;
private Date brith;
private Map<String,Object> maps;
private List<Object> lists;
private Dog dog;
将配置文件中配置的属性的值,映射到这个组件中
@ConfigurationProperties //告诉SpringBoot 将本类中所有属性 和 配置文件中的相关配置进行绑定;
prefix = “person” :配置文件中哪个下面的所有属性进行 一一映射
**@Component:**只有这个组件是容器中的组件,才能使用容器提供的功能。@ConfigurationProperties
我们可以导入配置文件处理器,以后编写配置就有提示了
<!--导入配置文件处理器,配置文件进行绑定就会有提示-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
测试文件
/**
* SpringBoot单元测试
* 可以在测试期间很方便的类似编码一样 进行自动注入等容器的功能
*/
@RunWith(SpringRunner.class)
@SpringBootTest
class SpringBoot01ConfigApplicationTests {
@Autowired
Person person;
@Test
void contextLoads() {
System.out.println(person);
}
}
注意:RunWith(SpringRunner.class)需要导入junit依赖
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>RELEASE</version>
</dependency>