SpringBoot
配置文件
SpringBoot使用一个全局的配置文件,配置文件名是固定的
application.properties
application.yaml
配置文件的作用:修改SpringBoot自动配置的默认值,底层自动关联
YAML(YAML Ain’t MarkupLanguage)
标记语言:
曾经的配置文件都是XML的,YAML是以数据为中心,比json、XML更适合做配置文件。
YAML写法:
1,基本语法
k(空格):v:表示一堆键值对(空格必须有)
以空格的缩进来控制层级关系:只要是左对齐的一列数据,都是同一个层级的
server:
port: 8081
2、值的写法
字面量:普通的值(数字、字符串、布尔)
k : v:字面直接来写:
字符串默认不用加上单双引号
“”:双引号:不会转移字符串里边的特殊字符,特殊字符作为本身的表示的意思
‘’:单引号:会转义特殊字符,特殊字符最终只是一个普通的字符串数据
对象、Map(属性和值)(键值对)
k : v:在下一行来写对象的属性和值的关系,注意缩进
对象还是KV的方式
friends:
lastname:zhangsan
age:20
行内写法:
friends:{lastname:zhangsan,age:20}
数组(List,set):
List
lists
- lisi
- god
- zhangsan
3、配置文件值注入
自定义配置文件的值,需要一个自定义的类
导入配置文件处理器
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
定义一个person类
/**
*
* @ConfigurationProperties标明自己是配置类,是配置文件中相关的配置进行绑定
* prefix为前缀,prefix = "person"配置文件中对“person”下面的所有属性进行映射
* @Component添加到容器内,只有这个组件是容器中的组件,容器才能提供@ConfigurationProperties功能
* @ConfigurationProperties(prefix = "person")默认是在全局配置文件中获取值
*/
@Component
@ConfigurationProperties(prefix = "person")
public class person {
private String name;
private Integer age;
private Boolean boss;
private Date birth;
private Map<String,String> maps;
private List<Object> lists;
private Dog dog
};
public class Dog {
private String name;
private Integer age;
}
对application.yml进行修改
person:
name: 张三
age: 18
boss: false
birth: 2019/9/3
maps: {k1: v1,k2: 2}
lists:
- lisi
- zhangsan
dog:
name: gou
age: 2
全部构建完成,我们准备一个测试类
/**
* SpringBoot的单元测试
* 可以在测试期间很方便的进行自动注入
*/
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringBootQuickHelloworldApplicationTests {
@Autowired
person persons;
@Test
public void contextLoads() {
System.out.println(persons);
}
}
运行后可以看到
PS: 此处定义的实体。必须实现getter,setter以及tostring的方法,可以通过ALT+Inerrt的快捷方式增加。
当你在application.properties中写中文的时候,需要对idea进行设置,选择utf-8,以及后边的转变为ascii码,方便程序运行的时候正确的获取到
@ConfigurationProperties | @value |
---|---|
批量注入配置文件中的属性 | 一个一个的绑定 |
支持松散绑定 | 不支持 |
JSR303支持 | JSP303不支持 |
SPEL不支持 | SPEL支持 |
复杂类型封装支持 | 复杂类型封装不支持 |
松散绑定
比如Last -name 与Last Name 在ConfigurationProperties都是可以识别的,但是value中就不可以
JSR303
ConfigurationProperties中我们可以给一个属性增加一个@Emile的验证,非emile格式就会报错,但是用value注入则直接通过。需要添加@Validated注解
SPEL
SPEL可以对数据进行计算,写入:@Value(“#{11*2}”),ConfigurationProperties中这么写会报错,value则可以计算。
复杂类型封装
比如List<>,Map,object等。
总结: 1,我们只是在某个业务逻辑中需要获取一下配置文件中的某项值,使用@value;
2,如果专门编写了javabean类和配置文件进行映射,使用@ConfigurationProperties;
@PropertySource(value = {“classpath:person.properties”}) 可以指定注入的配置文件。
@ImportResource(value = {“classpath:bean.xml”}) 导入Spring配置文件,让配置文件中的内容生效
以前导入XML打方式,SpringBoot已经不提倡。
我们现在采用注解的方式来导入配置文件。
4,配置文件占位符
1、随机数
random.value,(random.int),$(random.long),random.int(10),{random.int[1024,65535]}
2、占位符
person.name = 李四${random.int}
person.age=18
person.boss=false
person.birth= 2019/9/4
person.maps.k1= v1
person.maps.k2= 123
person.lists= lisi,zhangsan
person.dog.name= dogl
person.dog.age= 2
5、Profile
1、多个Profile文件{properties}
我们在主配置文件编写的时候。文件名可以是application-{Profile}.properties/yml的方式
默认使用application.properties
spring.profiles.active:可以设定指定的properties文件
properties文件可以通过spring.profiles来标明自己是什么类型
2、一个YAML的文档块模式
server:
port: 8081
spring:
profiles:
active: dev
---
server:
port: 8082
spring:
profiles: dev
---
server:
port: 8083
spring:
profiles: prod
3、激活指定的profiles
1、在配置文件中指定spring.profiles.active=dev
2、命令行:
java -jar spring-boot-001.jar --spring.profiles.active=dev
可以在测试的时候,直接指定
3、虚拟机方式:
-Dspring.profiles.active=dev
6、配置文档加载位置
springboot在加载配置文件的时候遵循一定的顺序性
-file…/config/
-file…/
-classpath:/config/
-classpath:/
优先级是按照从高到低的顺讯。所有位置的文件都会被加载,高优先级会覆盖低优先级的内容
,但是其他的配置文件也会全部加载,形成一种互补配置。
- 不过我们可以通过spring.config.location来改变默认的配置文件位置。
项目打包后,可以通过命令行的方式来指定–spring.config.location=G://xxx.properties
7、外部配置加载顺序
1、命令行
2、由jar包外向jar包内寻找,优先加载带profile的,再加载不带profile的,