SpringBoot(三) 配置文件 篇章
SpringBoot 配置文件默认为application.properties,但是本章节主要讲解yaml文件配置,因为现在的趋势是使用yaml,它是类似于标准通用标记语言的子集XML的数据描述语言,语法比XML简单很多。
pom文件贴在最后面:
一、自定义属性与加载
我们把之前项目中的配置文件application.properties改成application.yml
test:
user:
username : zhangsan
age : 18
toString: the age of ${test.user.username} is ${test.user.age}
属性类
package cn.saytime.bean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component
public class PropertiesConfig {
@Value("${test.user.username}")
private String username;
@Value("${test.user.age}")
private String age;
@Value("${test.user.toString}")
private String toString;
// ... Getter Setter
}
测试Controller
package cn.saytime.web;
import cn.saytime.bean.PropertiesConfig;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class TestController {
@Autowired
private PropertiesConfig propertiesConfig;
@RequestMapping(value = "test", method = RequestMethod.GET)
public String test(){
// return propertiesConfig.getUsername() + ":" + propertiesConfig.getAge();
return propertiesConfig.getToString();
}
}
访问 http://127.0.0.1/test
或者测试单元: 注意:要在springboot启动类下面新建测试类
package cn.demo;
import java.util.Properties;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
import cn.demo.bean.Config;
import cn.demo.bean.Person;
import cn.demo.bean.User;
@RunWith(SpringRunner.class)
@SpringBootTest
public class PropertiesTest {
@Autowired
private User user;
@Autowired
private Person person;
//新建的test.yml和 person.yml文件,取不到值,都是null,但是新建的person.properies可以取值。
@Test
public void test() {
System.out.println("server display name:" + user.getUsername());
System.out.println("server address:" + user.getAge());
System.out.println("server emain:" + user.getEmail());
}
@Test
public void test2() {
System.out.println("person-infomation:" + person.toString());
}
}
二、自定义属性注入bean
将上面application.yml文件中的test.user注入到User对象里,注意这里的prefix指定的是test.user,对应配置文件中的结构
@Component
@ConfigurationProperties(prefix = "test.user")
public class User {
private String username;
private int age;
public String getUsername() {
return username;
}
// Getter Setter
}
@RestController
public class TestController {
@Autowired
private User user;
@RequestMapping(value = "test2", method = RequestMethod.GET)
public String test2(){
return user.getUsername() + ":" + user.getAge();
}
}
访问 http://localhost:8080/test2 ==> zhangsan : 18
三、自定义额外的配置文件
比如我们不想把有些配置配置在application.yml/properties中。新建其他配置文件。这里比如新建test.yml文件。配置内容如上面的application.yml一样。那么我们注入对象时,应该这么写
@Configuration
@PropertySource(value = "classpath:test.yml")
@ConfigurationProperties(prefix = "test.user")
四、多个环境配置文件
在现实的开发环境中,我们需要不同的配置环境;格式为application-{profile}.properties,其中{profile}对应你的环境标识,比如:
application-test.properties:测试环境
application-dev.properties:开发环境
application-prod.properties:生产环境
怎么使用?只需要我们在application.yml中加:
spring:
profiles:
active: dev
因为主入口都是application.yml,这里指定配置文件为dev,即启用application-dev.yml文件
其中application-dev.yml:
server:
port: 8888
启动工程,发现程序的端口不再是8080,而是8888,表示开发环境配置成功。
六、官方支持默认配置文件属性
http://docs.spring.io/spring-boot/docs/1.5.4.RELEASE/reference/htmlsingle/#common-application-properties
七、属性加载优先级
1. @TestPropertySource 注解
2. 命令行参数
3. Java系统属性(System.getProperties())
4. 操作系统环境变量
5. 只有在random.*里包含的属性会产生一个RandomValuePropertySource
6. 在打包的jar外的应用程序配置文件(application-{profile}.properties,包含YAML和profile变量)
7. 在打包的jar内的应用程序配置文件(application-{profile}.properties,包含YAML和profile变量)
8. 在@Configuration类上的@PropertySource注解
9. 默认属性(使用SpringApplication.setDefaultProperties指定)
也就是说比如我配置文件配置了一个name=zhangsan,然后将项目打成jar,运行的时候,如果我们使用 java -jar app.jar --name="Spring",那么注入的进去的就是Spring,优先级高
八、配置文件优先级
查看SpringBoot官方文档,可以发现
翻译:
当前目录下的一个/config子目录
当前目录
一个classpath下的/config包
classpath根路径(root)
也就是说:如果我们有多个配置文件,比如 src/main/resource/application.yml
test:
user:
username : zhangsan
age : 18
toString: the age of ${test.user.username} is ${test.user.age}
name: SpringBoot-root
test2: ${test1}-root
test3: SpringCloud-root
server:
port: 8080
src/main/resource/config/application.yml
test:
user:
username: lisi-config
name: SpringBoot-config
test1: ${name}-config
test4: ${test3}-config
server:
port: 9090
根据优先级,可以得到能够加载到SpringBoot应用的属性为:
test:
user:
username : lisi
age : 18
toString: the age of lisi is 18
name: SpringBoot-config
test1: SpringBoot-config-config
test2: SpringBoot-config-config-root
test3: SpringCloud-root
test4: SpringCloud-root-config
server:
port: 9090
如果你能够得到上面的结果,表示你已经懂了。
注意优先级高的配置文件中存在和优先级低的配置文件相同属性时,取优先级高配置文件的,不冲突的时候,优先级低的配置文件属性同样会被加载,而不是只加载优先级高的配置文件属性。
九、简单总结
1、普通自定义属性,使用@Value("${xxx}")注入 2、注入对象,使用@ConfigurationProperties(prefix="test.user")
pom:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.demo</groupId>
<artifactId>springboot_peizhi</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>springboot_peizhi</name>
<url>http://maven.apache.org</url>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.4.RELEASE</version>
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-api -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.11.2</version>
</dependency>
<!-- Spring-Mybatis -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.0</version>
</dependency>
<!-- MySQL -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
</configuration>
</plugin>
</plugins>
</build>
</project>