3、SpringBoot2之配置文件

3.1、环境搭建

3.1.1、在project创建新module

3.1.2、选择maven

3.1.3、设置module名称和路径

3.1.4、module初始状态

3.1.5、引入springboot父工程

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.18</version>
    </parent>

3.1.6、引入启动器依赖

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>

3.1.7、创建启动类

package online.liaojy;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * @author liaojy
 * @date 2023/12/18 - 6:24
 */
@SpringBootApplication
public class MainApplication {

    public static void main(String[] args) {
        SpringApplication.run(MainApplication.class,args);
    }

}

3.1.8、创建控制器

package online.liaojy.controller;

import org.springframework.web.bind.annotation.RestController;

/**
 * @author liaojy
 * @date 2023/12/18 - 7:04
 */
@RestController
public class TestController {

}

3.2、统一配置管理概述

  • 在 Spring Boot 工程中,实行统一的配置管理,即所有参数配置都会集中到一个固定位置和命名的文件中;

  • 配置文件的固定位置是在 src/main/resources 目录下,该目录是 Spring Boot 工程默认的类路径(classpath);

  • 配置文件的命名格式为:application+后缀+扩展名,扩展名可以是 properties 、yaml 或 yml ;

  • 如果 application.properties 和 application.yml(.yaml) 同时存在,则 properties 的优先级更高。

在 Spring Boot 工程的统一配置文件中,有自定义的参数项,也有固定的参数项,固定的参数项及默认值见 Spring Boot 官方文档:
https://docs.spring.io/spring-boot/docs/2.7.18/reference/html/application-properties.html

3.3、properties配置文件

3.3.1、创建application.properties配置文件

# application.properties 为统一配置文件,既可以配置固定功能的参数项,也可以配置自定义的参数项

# 固定功能参数项的示例
server.port=8088
server.servlet.context-path=/application


# 自定义参数项的示例
my.name=liaojy

3.3.2、读取配置文件中的参数值

在统一配置文件中的参数项的值,都可以使用@Value("${键}")的方式直接读取,但一般都是读取自定义的参数项的值

    @Value("${my.name}")
    private String name;

    @RequestMapping("/readApplication")
    public String readApplication(){
        return "Hello,"+name+"!";
    }

3.3.3、测试效果

3.4、yaml配置文件(了解)

3.4.1、yaml概述

  • YAML(YAML Ain’t Markup Language)是一种基于层次结构的数据表示方式;

  • YAML配置文件的扩展名,可以是 yaml ,也可以是 yml ;

  • YAML 配置文件中的键和值之间使用冒号 “ : ” 分隔,并使用缩进表示层级关系,可以减少冗余的内容;

  • 相比起 properties 配置文件,YAML 配置文件支持复杂的数据类型,集合类型可以通过减号 “ - ” 来表示。

注意:因为 YAML 配置文件无法搜索完整的参数项名称,且空格和缩进的格式经常被人诟病,所以本文更推荐使用 properties 配置文件

3.4.2、创建application.yml配置文件

# application.yml 为统一配置文件,既可以配置固定功能的参数项,也可以配置自定义的参数项

# 固定功能参数项的(properties)示例
# server.port=8088
# server.servlet.context-path=/application

# 固定功能参数项的(yml)示例
server:
  port: 8088          # 注意冒号 “ : ” 和值之间有一个空格
  servlet:
    context-path: /application


# 自定义参数项的(properties)示例,properties不支持复杂的数据类型
# my.name=liaojy

# 自定义参数项的(yml)示例
my:
  name: liaojy
  hobby:              # yml支持复杂的数据类型,,集合类型可以通过减号 “ - ” 来表示
    - book
    - music
    - movie

3.4.3、读取配置文件中的参数值

读取 YAML 配置文件中参数值的方式,和读取 properties 配置文件中参数值的方式相同,都是使用@Value("${键}")的方式直接读取;

需要注意的是,使用@Value("${键}")的方式,不能读取集合类型(本例为 my.hobby )的值,
如果希望读取集合类型的值,则需要使用 @ConfigurationProperties 注解(详细见3.5节)

@Value("${my.name}")

3.4.4、测试效果

3.5、配置的批量注入

3.5.1、创建组件类

package online.liaojy.pojo;

import org.springframework.stereotype.Component;

import java.util.List;

/**
 * @author liaojy
 * @date 2023/12/19 - 7:12
 */
// @Component 注解的作用是将类标识为bean组件,因为只有在ioc容器中才能使用依赖注入给成员变量赋值
@Component
public class Me {

    private String name;

    private List<String> hobby;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public List<String> getHobby() {
        return hobby;
    }

    public void setHobby(List<String> hobby) {
        this.hobby = hobby;
    }

    @Override
    public String toString() {
        return "Me{" +
                "name='" + name + '\'' +
                ", hobby=" + hobby +
                '}';
    }

}

3.5.2、创建控制器方法

    @Autowired
    private Me me;

    @RequestMapping("/me")
    public Me me(){
        return me;
    }

3.5.3、@Value注解的不足

  • @Value 注解需要一个个读取配置文件中的参数值到成员变量中;

  • @Value 注解只能读取单个值,不能读取集合类型(本例为 my.hobby )的值。

    @Value("${my.name}")
    private String name;

    @Value("${my.hobby}")
    private List<String> hobby;

3.5.4、@ConfigurationProperties注解

  • @ConfigurationProperties 注解是 spring boot 提供的重要注解,其作用是可以将配置批量注入到 bean 对象中;

  • 只要 @ConfigurationProperties 注解指定的前缀 + bean 对象中的属性名称,和配置文件中的“键”保持一致即可注入成功;

  • 该注解的优点除了方便(不需要一个个读取配置文件中的参数值到成员变量中)之外,还支持给集合类型赋值。

@ConfigurationProperties(prefix = "my")

3.5.5、测试配置批量注入的效果

3.6、多环境的配置

  • 在一个项目的实际过程中,会存在不同的环境,例如开发、测试和生产环境;

  • 在不同的环境中,会使用不同的参数配置,例如数据库信息和日志级别等;

  • 在 spring boot 中,可以根据不同的运行环境来加载不同的配置。

注意:如果希望默认配置文件不太臃肿,也可以使用该功能将不同模块的配置参数存放到不同的配置文件中

3.6.1、配置文件分离

创建一个用于开发环境的配置文件 application-dev.properties

# 该文件的配置用于开发环境

my.name=liaojy_dev

创建一个用于测试环境的配置文件 application-test.properties

# 该文件的配置用于测试环境

my.name=liaojy_test

创建一个用于测试环境的配置文件 application-prod.properties

# 该文件的配置用于生产环境

my.name=liaojy_prod

3.6.2、激活配置文件

# application.properties(.yml) 是 spring boot 的默认配置文件
# 如果没有额外激活其他(有后缀的)配置文件,则默认只使用 application.properties(.yml)

my.name=liaojy_default

# spring.profiles.active 参数用于激活指定的配置文件
# 本例激活的是 application-dev.properties 配置文件
# 如果想激活多个配置文件,则使用逗号分隔,例如:spring.profiles.active=dev,test
spring.profiles.active=dev

3.6.3、配置参数的优先级

  • 如果设置了 spring.profiles.active ,但和 application.properties 无重叠的配置参数,则application.properties 的配置参数依然生效;

  • 如果设置了 spring.profiles.active ,并且和 application.properties 有重叠的配置参数,则以激活的配置参数优先;

  • 如果设置了 spring.profiles.active ,并且激活多个配置文件以及有重叠的配置参数,则以最后激活的配置参数优先。

3.6.4、测试效果

热门相关:陆鸣至尊神殿   写给鼹鼠先生的情书   我有一个进化点   诛天至极   魔葫