Spring默认使用YML中的配置,但有时候要用传统的XML或Properties配置,就需要使用spring-boot-configuration-processor了。

引入pom依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-configuration-processor</artifactId>
    <optional>true</optional>
</dependency>
author.name=Tom
author.age=20

在配置类开头加上@PropertySource("classpath:your.properties"),其余用法与加载YML的配置一样

@Component
@PropertySource(value = {"classpath:static/config/author.properties"},
        ignoreResourceNotFound = false, encoding = "UTF-8", name = "author.properties")
public class Author 
{
    @Value("${author.name}")
    private String name;
    
    @Value("${author.age}")
    private int age;
}

@PropertySource中的属性解释:

value:指明加载配置文件的路径。 
ignoreResourceNotFound:指定的配置文件不存在是否报错,默认是false。当设置为 true 时,若该文件不存在,程序不会报错。实际项目开发中,最好设置 ignoreResourceNotFound 为 false。 
encoding:指定读取属性文件所使用的编码,我们通常使用的是UTF-8。

当我们使用 @Value 需要注入的值较多时,代码就会显得冗余,于是 @ConfigurationProperties 登场了

@Component
@ConfigurationProperties(prefix = "author")
@PropertySource(value = {"classpath:static/config/author.properties"},
        ignoreResourceNotFound = false, encoding = "UTF-8", name = "author.properties")
public class Author
{
    private String name;
    private int age;
}

@RestController
@EnableConfigurationProperties
public class MyController {
 
    @Autowired
    Author author;
 
    @RequestMapping("/")
    public String index(){
        return "author's name is " + author.getName() + ", ahtuor's age is " + author.getAge();
    }
}

使用 @EnableConfigurationProperties 开启 @ConfigurationProperties 注解。