SpringBoot配置文件

boss: false
birth: 2017/12/12
maps: {k1: v1,k2: 12}
lists:
‐ lisi
‐ zhaoliu
dog:
name: 小狗
age: 12

对应的实体Bean为:

/**
* 将配置文件中配置的每一个属性的值,映射到这个组件中
* @ConfigurationProperties:告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定,默认是application.yml/application.properties;
*      prefix = “person”:配置文件中哪个key开始将下面的所有属性进行一一映射
* 只有当前实体Bean是容器中的组件,才能使用 @ConfigurationProperties开启自动注入配置功能;
*
*/
@Component
@ConfigurationProperties(prefix = “person”)
public class Person {
private String lastName;
private Integer age;
private Boolean boss;
private Date birth;
private Map<String,Obje

【一线大厂Java面试题解析+核心总结学习笔记+最新架构讲解视频+实战项目源码讲义】

浏览器打开:qq.cn.hn/FTf 免费领取

ct> maps;
private List lists;
private Dog dog;
}

使用这个功能,我们还可以将配置文件处理器的依赖添加进来,以后再去编写配置文件的时候就有属性提示了,会自动帮我们查找关联当前配置文件的实体Bean,pom坐标如下:

<!‐‐导入配置文件处理器,配置文件进行绑定就会有提示‐‐>
       
org.springframework.boot            
spring‐boot‐configuration‐processor            
true            

在需要获取对应配置的地方使用自动注入B该实体Bean即可

使用@Value获取值和@ConfigurationProperties获取值比较

同样在SpringBoot中我们还可以通过传统的方式–@Value注解的方式,将配置文件中的每一个属性单独注入到指定的字段中,而使用@Value和使用**@ConfigurationProperties**方式注入配置文件有何不同?我们将两种方式的区别是局限性列了表格,作为参照,表格如下:

@ConfigurationProperties@Value
功能批量注入配置文件中的属性一个个指定
松散绑定(松散语法)支持不支持
SpEL语法不支持支持
JSR303数据校验支持不支持
复杂类型封装支持不支持

前面我们通过@ConfigurationProperties读取了application.yml的配置信息,那么我们能不能读取其他的配置文件加载进对应的配置bean中呢?在SpringBoot中提供了一个**@PropertySource**的注解,可以指定加载的配置文件,例如:

@PropertySource(value = {“classpath:person.properties”})
@Component
@ConfigurationProperties(prefix = “person”)
public class Person {
private String lastName;
private Integer age;
private Boolean boss;
}

这样就可以指定其他的配置文件加载进对应的配置实体中

ImportResource

我们在使用Spring编程的时候,往往喜欢使用xml配置的方式配置对应的bean实例,而在SpringBoot中可以通过**@ImportResource**注解的方式,导入对应的xml配置文件,将其配置在某个配置类上,即可将xml配置文件中的实例注册,例如我们现在编写一个xml配置文件:

<?xml version="1.0" encoding="UTF‐8"?>



然后使用@ImportResource将xml配置文件导入:

//导入Spring的配置文件让其生效
@ImportResource(locations = {“classpath:beans.xml”})

而熟悉Spring注解驱动开发的应该明白,在Spring4.x版本开始,Spring支持全注解式申明Bean配置,而要完成注解式申明Bean,我们只需要**@Configuration替代xml配置文件,而在配置类中,我们需要注册的Bean可以使用@Bean** 将组件添加进Spring中,即可实现和xml配置一样的操作,例如:

/**
* @Configuration:指明当前类是一个配置类;就是来替代之前的Spring配置文件
*
在配置文件中用标签添加组件
*
*/
@Configuration
public class MyAppConfig {
//将方法的返回值添加到容器中;容器中这个组件默认的id就是方法名
@Bean
public HelloService helloService02(){
System.out.println(“往Spring中添加HelloService组件…”);
return new HelloService();
}
}

多Profile文件配置

我们在日常开发过程中往往会遇到需要多个环境使用多个配置的场景,这个时候我们往往会配置多个profile,即

application-{profile}.properties/yml 文件,而在yml中还支持多个文档块的方式配置,即可以在一个yml文件中配置多个profile环境的配置:

server:
port: 8081
spring:
profiles:
active: prod

server:
port: 8083
spring:
profiles: dev

server:
port: 8084
spring:
profiles: prod  #指定属于哪个环境

而使用也比较简单,可以选择以下几种方式指定默认激活的环境:

1.在配置文件中指定

我们在配置文件中可以指定

spring.profiles.active=dev

2.java启动命令参数指定

java -jar spring-boot-config.jar --spring.profiles.active=dev;

3.配置jvm虚拟机启动参数指定默认参数

-Dspring.profiles.active=dev

默认加载配置文件

还记得文章开篇我们说过,在SpringBoot中默认会扫描项目中的application.properties或者application.yml 文件作为Spring boot的默认配置文件,而SpringBoot中默认会从以下四个地方加载主配置文件,优先级由高到低,如下:

–file:./config/ ##工程所在跟目录平级的config目录
–file:./ ##工程所在根目录
–classpath:/config/ ##当前工程内的config包目录中
–classpath:/ ##当前工程的类加载范围内(包括jar中)

这里需要注意的是,SpringBoot默认加载机制由高优先级开始查找配置,如果多个文件中有同一个配置,并且配置得值不相同,那么SpringBoot并不会查找最后一个配置对应的值,而是以第一个查找到的值为主,即高优先级会覆盖低优先级的配置。当然除了SpringBoot默认的加载主配置文件的机制外,我们还可以通过在启动jar的java命令参数中加入spring.config.location参数,指定我们的默认主配置文件的位置,命令如下:

java -jar spring-boot-config.jar --spring.config.location=G:/application.properties

外部化配置文件加载顺序

除了我们命令指定的外部配置文件以外,SpringBoot还支持了多种加载外部化配置文件的策略,按照优先级从高到低排序,如下:

命令行参数

将一些我们需要的配置项在启动jar的时候,使用参数传递进去,如:

java -jar spring-boot-Config.jar --server.port=8087 --server.context-path=/abc

系统属性与环境变量

可以从**System.getProperties()**中获取配置在系统属性的参数,也可以从操作系统自身的配置的环境变量中获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值