1.5 全局配置文件
全局配置文件能够对一些默认配置值进行修改。Spring Boot 使用一个 application.properties 或者 application.yaml 的文件作为全局配置文件,该文件存放在 src/main/resource 目录或者类路径的 /config,一般会选择 resource 目录。接下来,将针对这两种全局配置文件进行讲解:
1.5.1 application.properties 配置文件
使用 Spring Initializr 方式构建 Spring Boot 项目时,会在 resource 目录下自动生成一个空的 application.properties 文件,Spring Boot 项目启动时会自动加载 application.properties 文件。
我们可以在 application.properties 文件中定义 Spring Boot 项目的相关属性,当然,这些相关属性可以是系统属性、环境变量、命令参数等信息,也可以是自定义配置文件名称和位置
server.port=8081
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.config.additional-location=
spring.config.location=
spring.config.name=application
1234567891011
接下来,通过一个案例对 Spring Boot 项目中 application.properties 配置文件的具体使用进行讲解
演示:
预先准备了两个实体类文件,后续会演示将 application.properties 配置文件中的自定义配置属性注入到 Person 实体类的对应属性中
(1)先在项目的 com.lagou 包下创建一个 pojo 包,并在该包下创建两个实体类 Pet 和 Person
public class Pet {
private String type;
private String name;
// 省略属性 getXX()和 setXX()方法
// 省略 toString()方法
}
1234567891011121314151617181920
@Component // 用于将 Person 类作为 Bean 注入到 Spring 容器中
@ConfigurationProperties(prefix =
“person”) // 将配置文件中以 person 开头的属性注入到该类中
public class Person {
private int id; //id
private String name; // 名称
private List hobby; // 爱好
private String[] family; // 家庭成员
private Map map;
private Pet pet; // 宠物
// 省略属性 getXX()和 setXX()方法
// 省略 toString()方法
}
1234567891011121314151617181920212223242526272829303132
@ConfigurationProperties(prefix =
“person”)注解的作用是将配置文件中以 person 开头的属性值通过 setXX()方法注入到实体类对应属性中
@Component 注解的作用是将当前注入属性值的 Person 类对象作为 Bean 组件放到 Spring 容器中,只有这样才能被 @ConfigurationProperties 注解进行赋值
(2)打开项目的 resources 目录下的 application.properties 配置文件,在该配置文件中编写需要对 Person 类设置的配置属性
编写 application.properties 配置文件时,由于要配置的 Person 对象属性是我们自定义的,Spring Boot 无法自动识别,所以不会有任何书写提示。在实际开发中,为了出现代码提示的效果来方便配置,在使用 @ConfigurationProperties 注解进行配置文件属性值注入时,可以在 pom.xml 文件中添加一个 Spring Boot 提供的配置处理器依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
12345678910
在 pom.xml 中添加上述配置依赖后,还需要重新运行项目启动类或者使用“Ctrl+F9”快捷键(即 Build Project)重构当前 Spring Boot 项目方可生效
(3)查看 application.properties 配置文件是否正确,同时查看属性配置效果,打开通过 IDEA 工具创建的项目测试类,在该测试类中引入 Person 实体类 Bean,并进行输出测试
@RunWith(SpringRunner.class) // 测试启动器,并加载 Spring Boot 测试注解
@SpringBootTest // 标记为 Spring Boot 单元测试类,并加载项目的 ApplicationContext 上下文环境
class SpringbootDemoApplicationTests {
// 配置测试
@Autowired
private Person person;
@Test
void
configurationTest() {
System.out.println(person);
}
}
12345678910111213141516171819202122232425262728