SpringBoot默认会从Resources目录下加载application.properties或application.yml(application.yaml)文件
其中,application.properties文件是键值对类型的文件,之前一直在使用,所以此处不在对properties文件的格式进行阐述。除了properties文件外,SpringBoot还可以使用yml文件进行配置,下面对yml文件进行讲解。
YML文件格式是YAML (YAML Aint Markup Language)编写的文件格式,YAML是一种直观的能够被电脑识别的的数据数据序列化格式,并且容易被人类阅读,容易和脚本语言交互的,可以被支持YAML库的不同的编程语言程序导入,比如: C/C++, Ruby, Python, Java, Perl, C#, PHP等。YML文件是以数据为核心的,比传统的xml方式更加简洁。
YML文件的扩展名可以使用.yml或者.yaml。
简单类型
在Spring Boot 2.0中对配置属性加载的时候会除了像1.x版本时候那样移除特殊字符外,还会将配置均以全小写的方式进行匹配和加载。所以,下面的4种配置方式都是等价的:
- properties格式:
spring.jpa.databaseplatform=mysql
spring.jpa.database-platform=mysql
spring.jpa.databasePlatform=mysql
spring.JPA.database_platform=mysql
- yaml格式:
spring:
jpa:
databaseplatform: mysql #行注释
database-platform: mysql
databasePlatform: mysql
database_platform: mysql
注意:
-
key与value之间的存在一个空格
-
配置可以使用驼峰式也可以使用-分隔符,推荐使用全小写配合分隔符的方式来配置,比如:
-
行注释#前面有个空格
List(set,数组)类型
在properties文件中使用来定位列表类型,比如:
student.name[0]=孙悟空
student.name[1]=张三丰
也支持使用逗 分割的配置方式,上面与下面的配置是等价的:
student.name=孙悟空,张三丰
而在yaml文件中使用可以使用如下配置:
student:
name:
-
孙悟空
-
张三丰
注意 – 后有空格 出现关机字可以用””括起来
也支持逗 分割的方式:
student:
name: 孙悟空, 张三丰
或者
student:
name: [孙悟空, 张三丰]
集合中的元素是对象(或map)形式:
student:
- name: zhangsan
age: 18
score: 100
- name: lisi
age: 28
score: 88
- name: wangwu
age: 38
score: 90
注意:在Spring Boot 2.0中对于List类型的配置必须是连续的,不然会抛出异常,所以如下配置是不允许的:
foo[0]=a
foo[2]=b
在Spring Boot 1.x中上述配置是可以的,由于没有配置,它的值会是
Map(对象)类型
Map类型在properties和yaml中的标准配置方式如下:
- properties格式:
spring.my-example.foo=bar
spring.my-example.hello=world
- yaml格式:
spring:
my-example:
foo: bar
hello: world
注意:如果Map类型的key包含非字母数字和的字符,需要用括起来,比如:
spring:
my-example:
‘[foo.baz]’: bar
注入Map(String,Object)格式的map对象:
@Service(“mc_member:openMemberCard”)//这是map的key
public class RegisterServiceImpl implements WmeimobMsgService {
@Override
public boolean execute(String param) {
// todo 执行推送会员信息
return false;
}
}
@Autowired
private Map
配置文件与配置类的属性映射方式
使用注解@Value映射:
application.properties配置:
person.name=zhangsan
person.age=18
或者,application.yml配置:
person:
name: zhangsan
age: 18
- 然后通过注解来加载对应的配置属性:
@Controller
public class QuickStartController {
@Value(“${person.name}”)
private String name;
//设置默认值,person.name:是空值
@Value(“${person.name:王大拿}”)
private String name2;
@Value(“${person.age}”)
private Integer age;
@RequestMapping(“/quick”)
@ResponseBody
public String quick(){
return “springboot 访问成功! name=”+name+”,age=”+age;
}
}
使用@Value注入map、List稍微复杂
配置文件
list: topic1,topic2,topic3
maps: “{key1: ‘value1’, key2: ‘value2’}
实体类
@Value(“#{’${list}’.split(’,’)}”)
private List list;
@Value(“#{${maps}}”)
private Map
- 使用注解@ConfigurationProperties映射对象(配置文件与对象绑定)
通过注解@ConfigurationProperties(prefix=“配置文件中的key的前缀,可以使properties文件也可以是yml文件”)可以将配置文件中的配置自动与实体进行映射(这个注解能作用在类上也能作用在方法上)
实体Bean代码如下:
@Controller
//@PropertySource(“classpath:/production/wxpay.properties”) //的值是配置文件文件的路径
@ConfigurationProperties(prefix = “person”)//配置文件前缀
public class QuickStartController {
private String name;
private Integer age;
@RequestMapping(“/quick”)
@ResponseBody
public String quick(){
return “springboot 访问成功! name=”+name+”,age=”+age;
}
public void setName(String name) {
this.name = name;
}
public void setAge(Integer age) {
this.age = age;
}
}
注意:使用@ConfigurationProperties方式可以进行配置文件与实体字段的自动映射,但需要字段必须提供set方法才可以,而使用@Value注解修饰的字段不需要提供set方法

@PropertySource(“classpath:/production/wxpay.properties”) 的值是properties文件的路径,如果是默认配置文件可以不写此注解
@ConfigurationProperties(prefix = “wxpay”) prefix属性值是配置文件key的前缀
也可以这样写:
@Component
public class SysConfiguration {
@Bean
@ConfigurationProperties(“wxpay”)
public WxPayBean wxPayBean() {
return new WxPayBean();
}
}
个人觉得这种方式更好,pojo就做最纯正的pojo不写别的
——————————————————————–扩展——————————————————
参数间的引用
在中的各个参数之间也可以直接引用来使用,就像下面的设置:
com.didispace.blog.name=圈圈
com.didispace.blog.title=Spring Boot教程
com.didispace.blog.desc=com.didispace.blog.name正 在 努 力 写 《 {com.didispace.blog.name}正在努力写《 com.didispace.blog.name正在努力写《{com.didispace.blog.title}》
参数引用了上文中定义的和属性,最后该属性的值就是。
使用随机数
在一些情况下,有些参数我们需要希望它不是一个固定的值,比如密钥、服务端口等。Spring Boot的属性配置文件中可以通过来产生int值、long值或者string字符串,来支持属性的随机值。
随机字符串
com.didispace.blog.value=${random.value}
随机int
com.didispace.blog.number=${random.int}
随机long
com.didispace.blog.bignumber=${random.long}
10以内的随机数
com.didispace.blog.test1=${random.int(10)}
10-20的随机数
com.didispace.blog.test2=${random.int[10,20]}
通过命令行设置属性值
相信使用过一段时间Spring Boot的用户,一定知道这条命令:,通过使用—server.port属性来设置xxx.jar应用的端口为8888。
在命令行运行时,连续的两个减 就是对中的属性值进行赋值的标识。所以,命令,等价于我们在中添加属性,该设置在样例工程中可见,读者可通过删除该值或使用命令行来设置该值来验证。
通过命令行来修改属性值固然提供了不错的便利性,但是通过命令行就能更改应用运行的参数,那岂不是很不安全,所以Spring Boot也贴心的提供了屏蔽命令行访问属性的设置,只需要这句设置就能屏蔽:。
多环境配置
《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》
【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享
我们在开发Spring Boot应用时,通常同一套程序会被应用和安装到几个不同的环境,比如:开发、测试、生产等。其中每个环境的数据库地址、服务器端口等等配置都会不同,如果在为不同环境打包时都要频繁修改配置文件的话,那必将是个非常繁琐且容易发生错误的事。
对于多环境的配置,各种项目构建工具或是框架的基本思路是一致的,通过配置多份不同环境的配置文件,再通过打包命令指定需要打包的内容之后进行区分打包,Spring Boot也不例外,或者说更加简单。
在Spring Boot中多环境配置文件名需要满足的格式,其中对应你的环境标识,比如:
- :开发环境
- :测试环境
- :生产环境
至于哪个具体的配置文件会被加载,需要在文件中通过属性来设置,其值对应值。
如:就会加载配置文件内容
下面,以不同环境配置不同的服务端口为例,进行样例实验。
-
针对各环境新建不同的配置文件、、
-
在这三个文件均都设置不同的属性,如:dev环境设置为1111,test环境设置为2222,prod环境设置为3333
-
application.properties中设置,就是说默认以dev环境设置
-
测试不同配置的加载
-
执行,可以观察到服务端口被设置为,也就是默认的开发环境(dev)
-
执行,可以观察到服务端口被设置为,也就是测试环境的配置(test)
-
执行,可以观察到服务端口被设置为,也就是生产环境的配置(prod)
按照上面的实验,可以如下总结多环境的配置思路:
-
中配置通用内容,并设置,以开发环境为默认配置
-
中配置各个环境不同的内容
-
通过命令行方式去激活不同环境的配置
配置文件绑定
环境属性绑定
简单类型
在环境变量中通过小写转换与替换来映射配置文件中的内容,比如:环境变量的配置会产生与在配置文件中设置一样的效果。
List类型
由于环境变量中无法使用和符 ,所以使用来替代。任何由下划线包围的数字都会被认为是的数组形式。比如:
MY_FOO_1_ = my.foo[1]
文章知识点与官方知识档案匹配,可进一步学习相关知识Java技能树首页概览93644 人正在系统学习中
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!