引言
在前文中介绍了SpringBoot通过注解方式读取yml配置文件中的配置,但在实际开发中往往 配置项的增多在yml文件中进行配置则显得十分臃肿,所以SpringBoot提供了@PropertySource和@ImportResource两个注解用于加载外部配置文件使用。下面将介绍这两个注解的使用方法。
@PropertySource通常用于属性加载配置文件,注意@PropertySource注解不支持加载yaml文件,支持properties文件。
@ImportResource通常用于加载Spring的xml配置文件
一、@PropertySource使用
装配properties配置文件
在resources/config下创建一个yaml文件命名为user.properties。
内容例如:
user.username=admin
user.password=123
javabean引用:
@PropertySource(value = {"classpath:config/user.properties"})
@Component
@ConfigurationProperties(prefix = "user")
public class User{
private String username;
private String password;
...
}
按照上述配置之后,就可以使用@Autowired来引用,通过get方法从而调用外部自定义配置了。
同时加载多个配置问题
细心的你,会发现@PropertySource注解中属性value为一个数组,如果同时加载多个配置文件,并且不同配置文件中对同一个属性设置了不同的值,那么Spring会识别哪一个呢?
带着疑问,我们可以通过控制变量法进行测试,具体过程再在赘述。
@PropertySource(value = {“classpath:config/user1.properties”,“classpath:config/user2.properties”})
结论:Spring加载顺序为从左到右顺序加载,后加载的会覆盖先加载的属性值。
二、@ImportResource使用
SpringBoot提出零xml的配置,因此SpringBoot默认情况下时不会识别项目中Spring的xml配置文件。为了能够加载xml的配置文件,SpringBoot提供了@ImportResource注解该注解可以加载Spring的xml配置文件,通常加于启动类上。
@ImportResource(value = {"classpath:/spring.xml"})
@SpringBootApplication
public class TestApplication {
public static void main(String[] args) {
SpringApplication.run(TestApplication.class, args);
}
}