乐趣区

SpringBoot基础回顾3

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

退出移动版