在src/main/resources下添加配置文件application.propertieshtml
例如修改端口号java
#端口号 server.port=8089
在src/main/resources下添加,application-pro.properties,application-dev.properties和application.properties三个文件spring
application.propertiesapp
配置属性激活的文件 spring.profiles.active=dev
application-pro.propertiesurl
#端口号 server.port=80 #自定义端口号读取 my.name=pzr.dev
application-dev.propertiesspa
#端口号 server.port=8089 #自定义端口号读取 my.name=pzr.pro
当application.propertie设置spring.profiles.active=dev时,则说明是指定使用application-dev.properties文件进行配置code
一、@PropertySource配置文件路径设置,在类上添加注解,若是在默认路径下能够不添加该注解。server
须要用@PropertySource的有:htm
例如非application.properties,classpath:config/my.properties指的是src/main/resources目录下config目录下的my.properties文件,blog
例若有多配置文件引用,若取两个配置文件中有相同属性名的值,则取值为最后一个配置文件中的值
在application.properties中的文件,直接使用@Value读取便可,applicarion的读取优先级最高
@PropertySource({"classpath:config/my.properties","classpath:config/config.properties"}) public class TestController
二、@Value属性名,在属性名上添加该注解
@Value("${my.name}") private String myName;
yaml格式
@Value("#{'${list}'.split(',')}") private List<String> list; @Value("#{${maps}}") private Map<String,String> maps; @Value("#{${redirectUrl}}") private Map<String,String> redirectUrl;
配置文件
list: topic1,topic2,topic3 maps: "{key1: 'value1', key2: 'value2'}" redirectUrl: "{sso_client_id: '${id}',sso_client_secret: '${secret}',redirect_url: '${client.main.url.default}'}"
注意:
上面的list配置中,必定不要用“”把list全部的成员value包起来,要否则解析报错。
上面的map配置中,必定要用“”把map所对应的value包起来,要否则解析会失败,致使不能转成 Map<String,String>。