YAML文件简介
在使用开发工具初始化一个SpringBoot项目之后,我们可以看到在src\main\resources目录下有一个application.properties文件,这个properties文件就是SpringBoot项目的全局配置文件。除了可以使用默认的application.properties文件作为全局配置文件之外,SpringBoot项目还支持另外一种全局配置文件——application.yml
YAML(YAML Ain't Markup Language)语言文件,它以.yml作为后缀。相比于传统的xml、properties文件,它的语法更加简洁、可读性更强,它的特点是以数据为中心,更加适合作为项目的配置文件
YAML基本语法
基本语法:
1.定义数据的格式为key: value,表示一对键值对(注意:value与冒号之间一定要有空格)
2.使用缩进表示层级关系
3.缩进时不允许使用Tab键,只允许使用空格
4.缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
5.大小写敏感
示例:
#配置数据库参数 同一层级的元素一定要左侧对齐
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/test
username: root
password: 123456
支持的数据结构:
1.对象(Map):键值对的集合
示例:
person:
name: Allen
age: 20
或者使用行内写法:
person: {name: Allen,age: 20}
2.数组(List、Set、Array):一组按次序排列的值
示例:
colors:
- red
- blue
- green
行内写法:
colors: [red, blue, green] # 方括号[]可以省略
3.字面量(int、long、boolean、String):单个的、不可再分的值
age: 20
city: New York
YAML文件值注入
通过使用@ConfigurationProperties注解,我们可以将YAML配置文件中相关配置的值与javabean进行绑定
新建一个Person类:
public class Address {
private String city; //城市
private Long streetNumber; //街区编号
//省略get/set、toString方法
}
/**
* 将配置文件中配置的每一个属性的值,映射到这个组件中
* @ConfigurationProperties:将本类中的所有属性和配置文件中相关的配置进行绑定
* prefix = "person":配置文件中哪个下面的所有属性进行一一映射
*/
@Component
@ConfigurationProperties(prefix = "person")
public class Person {
private String name; //姓名
private Integer age; //年龄
private Boolean student; //是否是学生
private Date birthday; //生日
private Map<String, Object> scores; //考试分数
private List<String> colors; //喜爱的颜色
private String[] foods; //喜爱的食物
private Address address; //家庭住址
//省略get/set、toString方法
}
application.yml文件配置:
person:
name: Allen
age: 20
student: true
birthday: 1998/10/20
scores: {math: 90,computer: 85,physics: 75}
colors: red, blue, green
foods:
- bread
- milk
- hamburger
address:
city: New York
streetNumber: 1005
在pom.xml中添加文件处理器依赖:
<!--导入配置文件处理器,导入后配置文件进行绑定就会有提示-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
单元测试:
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootYamlApplicationTests {
@Autowired
Person person;
@Test
public void contextLoads() {
System.out.println(person);
}
}
运行结果:
Person{name='Allen', age=20, student=true, birthday=Tue Oct 20 00:00:00 CST 1998, scores={math=90, computer=85, physics=75}, colors=[red, blue, green], foods=[bread, milk, hamburger], address=Address{city='New York', streetNumber=1005}}
除了使用@ConfigurationProperties进行批量值注入之外,我们还可以使用@Value注解对javabean进行单个值的注入
@Component
public class Person {
@Value("${person.name}")
private String name; //姓名
@Value("#{10+30/2}")
private Integer age; //年龄
@Value("false")
private Boolean student; //是否是学生
private Date birthday; //生日
private Map<String, Object> scores; //考试分数
private List<String> colors; //喜爱的颜色
private String[] foods; //喜爱的食物
private Address address; //家庭住址
//省略get/set、toString方法
}
单元测试:
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootYamlApplicationTests {
@Autowired
Person person;
@Test
public void contextLoads() {
System.out.println(person);
}
}
运行结果:
Person{name='Allen', age=25, student=false, birthday=null, scores=null, colors=null, foods=null, address=null}
与@ConfigurationProperties注解相比,@Value既可以注入application.yml中配置的值,也可以注入自定义值
@Value获取值和@ConfigurationProperties获取值比较
@PropertySource、@ImportResource、@Bean注解详解
1.@PropertySource注解
application.properties是SpringBoot项目默认的全局配置文件,如果我们将项目中的所有配置都写在application.properties文件中,必然会使得文件内容过于庞大,不容易维护。@PropertySource注解可以帮助我们解决这个问题,它可以加载指定的properties配置文件
在resource目录下新建person.properties文件
person.name=Paul
person.age=22
person.student=true
person.birthday=1996/08/12
person.scores.math=90
person.scores.computer=85
person.scores.physics=75
person.colors=[red, blue, green]
person.foods=[bread, milk, hamburger]
person.address.city=New York
person.address.streetNumber=1005
在Person 类上添加@PropertySource注解
@Component
@PropertySource(value={"classpath:person.properties"})
@ConfigurationProperties(prefix = "person")
public class Person {
private String name; //姓名
private Integer age; //年龄
private Boolean student; //是否是学生
private Date birthday; //生日
private Map<String, Object> scores; //考试分数
private List<String> colors; //喜爱的颜色
private String[] foods; //喜爱的食物
private Address address; //家庭住址
//省略get/set、toString方法
}
单元测试:
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootYamlApplicationTests {
@Autowired
Person person;
@Test
public void contextLoads() {
System.out.println(person);
}
}
运行结果:
Person{name='Paul', age=22, student=true, birthday=Mon Aug 12 00:00:00 CST 1996, scores={physics=75, math=90, computer=85}, colors=[[red, blue, green]], foods=[[bread, milk, hamburger]], address=Address{city='New York', streetNumber=1005}}
2.@ImportResource注解
程序员手动编写的Spring配置文件在SpringBoot项目中并不会被加载生效,要使SpringBoot项目加载Spring配置文件,则必须使用@ImportResource注解,将其标注在项目的启动类上
新建一个User测试类
public class User {
private Long id;
private String name;
}
编写Spring配置文件spring.xml
<?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="user" class="com.yaml.entity.User"></bean>
</beans>
在启动类上添加@ImportResource注解,使其加载spring.xml文件
@ImportResource(locations = {"classpath:spring.xml"})
@SpringBootApplication
public class SpringBootYamlApplication {
public static void main(String[] args) {
SpringApplication.run(SpringBootYamlApplication.class, args);
}
}
单元测试:
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootYamlApplicationTests {
@Autowired
BeanFactory beanFactory;
@Test
public void contextLoads() {
boolean flag = beanFactory.containsBean("user");
System.out.println("flag=" + flag);
}
}
运行结果:
flag=true
3.@Bean注解
@Bean注解用于给Spring容器中添加组件,这是SpringBoot官方推荐的方式
首先创建一个配置类,使用@Configuration标识
/**
* @Configuration:表示当前类是一个配置类
*/
@Configuration
public class MyAppConfig {
//将方法的返回值添加到容器中,方法名就是容器中这个组件默认的id
@Bean
public User userBean() {
return new User();
}
}
单元测试:
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootYamlApplicationTests {
@Autowired
BeanFactory beanFactory;
@Test
public void contextLoads() {
boolean flag = beanFactory.containsBean("userBean");
System.out.println("flag=" + flag);
}
}
运行结果:
flag=true