大家好,我是二师兄,本篇文章为大家讲解SpringBoot相关配置功能,包括配置文件、外部配置、属性注入等。
配置文件
基本配置支持
创建SpringBoot项目,会在src/main/resources目录下生成application.properties文件,这就是SpringBoot默认指定的配置文件。基本使用方式如下:
server.port=8080server.servlet.context-path=/hello
同时,SpringBoot也支持YAML格式的配置,同样将application.yml文件放置在resources目录下即可。YAML是以数据为中心的语言,配置的时候具有面向对象的特性。这两种配置形式都是SpringBoot推荐的,但对于比较复杂的数据来说,yaml的配置要优于properties。yaml配置具体示例:
server: port: 8080 servlet: context-path: /hello
YAML基本要求:
- YAML大小写敏感;
- 使用缩进代表层级关系;
- 缩进只能使用空格,不能使用TAB,不要求空格个数,只需要相同层级左对齐(一般2个或4个空格)
如果一个项目中同时出现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目录下。
它们的优先级依次为:
- 工程根目录:./config/
- 工程根目录:./
- classpath:/config/
- classpath:/
SpringBoot也支持通过命令来指定配置文件的位置:
--spring.config.location=/usr/local/config/
使用xml配置
当无法避免使用xml配置时,可以采用@ImportResources来进行xml配置的加载。
@ImportResource("classpath:mq.xml")
命令行参数配置
除了上面的参数配置之外,SpringBoot还提供了命令参数配置,比如在运行jar -jar时可以添加一些额外的参数来进行指定。
java -jar xx.jar —server.port=8080
此种方式的优先级最高。
自定义配置属性
除了可以按照SpringBoot的约定配置参数之外,我们还可以自定义一些参数,然后通过@Value或@ConfigurationProperties进行配置。也可以不使用默认的配置文件名,而通过@PropertiesSource进行配置文件路径的指定。
@Value注入属性值
在application配置文件中自定义好具体的属性,然后通过@Value注解在需要使用的地方进行注入。属性的自定义:
# 自定义属性admin.name=Tomadmin.age=25admin.phone=156********
在需要对应属性的地方注解使用,其中在表达冒号后面的Guest为指定的默认值,即如果找不到admin.name,则使用此默认值。
@Value("${admin.name:Guest}")private String adminName; @RequestMapping("/hello")public String hello(){ return "Hello admin:" + adminName + "!";}
@ConfigurationProperties配置
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开始。
@ConfigurationProperties的使用支持松散绑定,如:驼峰命名(userName)、横干拼接(user-name)、下划线(user_name)之间可以互相识别绑定。
绑定对象的使用:
@Resourceprivate SystemAdmin systemAdmin; @RequestMapping("/hello")public String hello(){ return "Hello admin:" + systemAdmin.getName() + "!";}
profile配置
在真是实践中,我们的配置文件会根据不同的环境有不同的配置文件,SpringBoot也为我们准备好了相应的配置。首先不同环境的配置按照指定的格式进行命名。比如:
- 开发环境:application-dev.properties
- 测试环境:application-test.properties
- 生产环境:application-prod.properties
Spring Boot 则通过 application.properties 文件中设置 spring.profiles.active 属性来指定加载文件。比如 ,参数值配置为 dev ,则加载的是 application-dev.properties 。