第一部分
application.yml
server:
port: 8081
Person:
lastName: zhangsan
age: 20
boss: true
brith: 2020/12/12
maps: {k1:v1,k2:v2}
list:
- list1
- list2
- list3
dog:
name: gou
age: 123
Person.java
/**
* 将配置文件中配置的每一个属性的值,映射到这个组件中
* @ConfigurationProperties:告诉SpringBoot将本类中的所有属性和配置文件中的相关配置进行绑定
* prefix = "person" 配置文件中哪个下面的所有属性进行一一映射
*/
//@EnableConfigurationProperties(Person.class)
@Component
@ConfigurationProperties(prefix = "person")
public class Person {
private String lastName;
private Integer age;
private Boolean boss;
private Date brith;
private Map<String,Object> maps;
private List list;
private Dog dog;
}
Dog.java
public class Dog {
private String name;
private Integer age;
}
pom.xml中导入坐标
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
第二部分
application.properties
# idea 配置文件 utf-8
# properties配置Person数据
person.last-name=小花
person.age=20
person.boss=false
person.brith=2020/10/10
person.maps.k1=v1
person.maps.k2=k2
person.list=a,b,c,d,e,f
person.dog.name=dog
person.dog.age=30
此时也可以使用@ConfigurationProperties(prefix = "person")
@Value标签
/**
* 将配置文件中配置的每一个属性的值,映射到这个组件中
* @ConfigurationProperties:告诉SpringBoot将本类中的所有属性和配置文件中的相关配置进行绑定
* prefix = "person" 配置文件中哪个下面的所有属性进行一一映射
*/
@Component
//@ConfigurationProperties(prefix = "person")
public class Person {
@Value("${person.last-name}")
private String lastName;
@Value("#{10*2}")
private Integer age;
@Value("${person.boss}")
private Boolean boss;
@Value("${person.brith}")
private Date brith;
}
第三部分·
yml和properties的加载顺序和区别
正常的情况是先加载yml,接下来加载properties文件。如果相同的配置存在于两个文件中。最后会使用properties中的配置。最后读取的优先集最高。
两个配置文件中的端口号不一样会读取properties中的端口号。
我在 application.properties 文件中配置了:
server.port=8080
在 application.yml 文件中配置了:
server:
port: 8081
启动SpringBoot项目,控制台输出:
Tomcat started on port(s): 8080 (http) with context path ''
@Value与@ConfigurationProperties的比较
@Value | @ConfigurationProperties | |
---|---|---|
功能 | 批量注入配置文件中的属性 | 一个个指定 |
松散绑定(松散语法) | 支持 | 不支持 |
SpEL | 不支持 | 支持 |
JSR303数据校验 | 支持 | 不支持 |
复杂类型封装 | 支持 | 不支持 |
@PropertySource(value = {“classpath:person.properties”})加载指定位置的配置
@PropertySource(value = {"classpath:person.properties"})
@Component
//此注解也需要
@ConfigurationProperties(prefix = "person")
public class Person {
//@Value("${person.last-name}")
private String lastName;
//@Value("#{10*2}")
private Integer age;
//@Value("${person.boss}")
private Boolean boss;
//@Value("${person.brith}")
private Date brith;
private Map<String,Object> maps;
private List list;
private Dog dog;
@ImportResource:导入Spring的配置文件,让配置文件里面的内容生效;SpringBoot里面没有Spring的配置文件,我们自己编写的配置文件,也不能自动识别;想让Spring的配置文件生效,加载进来;@ImportResource标注在一个配置类上。
@ImportResource(value = {"classpath:bean.xml"})
//导入Spring的配置文件,让配置文件里面的内容生效;
SpringBoot中推荐使用配置类,加@Configuration注解
/**
* 指明当前类是一个配置类;就是来替代之前的Spring配置文件
* 在配置文件中用<bean></bean>标签添加组件
* 默认使用方法名作为组件名
* 1、配置类====Spring配置文件
* 2、使用@Bean给容器添加组件
*/
@Configuration
public class MyConfig {
@Bean
public HelloService helloService(){
System.out.println("给容器添加组件了");
return new HelloService();
}
}