大家好,我是二师兄,本篇文章为大家讲解SpringBoot相关配置功能,包括application.properties配置文件、外部配置、属性注入等。
创建SpringBoot项目,会在src/main/resources目录下生成application.properties文件,这就是SpringBoot默认指定的配置文件。基本使用方式如下:
server.port=8080 server.servlet.context-path=/hello
同时,SpringBoot也支持YAML格式的配置,同样将application.yml文件放置在resources目录下即可。YAML是以数据为中心的语言,配置的时候具有面向对象的特性。这两种配置形式都是SpringBoot推荐的,但对于比较复杂的数据来说,yaml的配置要优于properties。yaml配置具体示例:
server: port: 8080 servlet: context-path: /hello
YAML基本要求:
如果一个项目中同时出现application.properties和application.yml文件配置的话,SpringBoot会如何处理呢?会优先使用properties中属性,然后再考虑使用yml文件中的属性。比如,上面的例子中,如果properties中不配置port,而yml配置port为8081,则启动后端口为8081,但是如果properties中配置为8080,则启动时以properties为准。
为什么我们将配置文件放置在resources目录下,SpringBoot就可以帮忙我们进行解析加载?下面通过源代码看一下SpringBoot默认会扫描哪些路径下的哪些配置文件。来看一下ConfigFileApplicationListener类,该类在spring-boot包下,通过该类的注释可以了解到基本的加载信息。
package org.springframework.boot.context.config; public class ConfigFileApplicationListener implements EnvironmentPostProcessor, SmartApplicationListener, Ordered { private static final String DEFAULT_PROPERTIES = "defaultProperties"; // Note the order is from least to most specific (last one wins) private static final String DEFAULT_SEARCH_LOCATIONS = "classpath:/,classpath:/config/,file:./,file:./config/"; private static final String DEFAULT_NAMES = “application”; // 省略其他代码 }
通过该类的常量定义,我们可以看到,默认加载的配置文件名为application,会加载以下目录下的配置文件:classpath目录、classpath目录下的config目录、工程根目录下、工程根目录的config目录下。
它们的优先级依次为:
SpringBoot也支持通过命令来指定配置文件的位置:
--spring.config.location=/usr/local/config/
当无法避免使用xml配置时,可以采用 @ImportResources 来进行xml配置的加载。
@ImportResource("classpath:mq.xml")
除了上面的参数配置之外,SpringBoot还提供了命令参数配置,比如在运行jar -jar时可以添加一些额外的参数来进行指定。
java -jar xx.jar —server.port=8080
此种方式的优先级最高。
除了可以按照SpringBoot的约定配置参数之外,我们还可以自定义一些参数,然后通过 @Value 或 @ConfigurationProperties 进行配置。也可以不使用默认的配置文件名,而通过 @PropertiesSource 进行配置文件路径的指定。
在application配置文件中自定义好具体的属性,然后通过 @Value 注解在需要使用的地方进行注入。属性的自定义:
# 自定义属性 admin.name=Tom admin.age=25 admin.phone=156********
在需要对应属性的地方注解使用,其中在表达冒号后面的Guest为指定的默认值,即如果找不到admin.name,则使用此默认值。
@Value("${admin.name:Guest}") private String adminName; @RequestMapping("/hello") public String hello(){ return "Hello admin:" + adminName + "!"; }
SpringBoot还提供了基于类型安全的配置方式,通过 @ConfigurationProperties 将一组配置和一个Bean关联起来,批量进行类型安全的自动注入。
@Component @PropertySource("classpath:my.properties") @ConfigurationProperties(prefix = "admin") public class SystemAdmin { private String name; private int age; // 省略getter/setter方法 }
其中, @Component 表示将此类实例化, @PropertySource 指定自定义的properties文件, @ConfigurationProperties (prefix = “admin”)指定实现配置属性和bean直接的关联,prefix指定匹配属性的前缀都以admin开始。
其中, @Component 表示将此类实例化, @PropertySource 指定自定义的properties文件, @ConfigurationProperties (prefix = “admin”)指定实现配置属性和bean直接的关联,prefix指定匹配属性的前缀都以admin开始。
@ConfigurationProperties 的使用支持松散绑定,如:驼峰命名(userName)、横干拼接(user-name)、下划线(user_name)之间可以互相识别绑定。
绑定对象的使用:
@Resource private SystemAdmin systemAdmin; @RequestMapping("/hello") public String hello(){ return "Hello admin:" + systemAdmin.getName() + "!"; }
在真是实践中,我们的配置文件会根据不同的环境有不同的配置文件,SpringBoot也为我们准备好了相应的配置。首先不同环境的配置按照指定的格式进行命名。比如:
Spring Boot 则通过 application.properties 文件中设置 spring.profiles.active 属性来指定加载文件。比如 ,参数值配置为 dev ,则加载的是 application-dev.properties 。