在 Spring Boot 中,配置文件有两种不同的格式properties和yaml 。
properties | yaml |
---|---|
比较常见 | 简洁明了,场景多 |
无序 | 有序 |
位置问题
在 Spring Boot 中,一共有 4 个地方可以存放 application.properties 文件。优先级依次降低,如下:
- 当前项目根目录下的 config 目录下
- 当前项目的根目录下
- resources 目录下的 config 目录下
- resources 目录下
注:亦自定义配置文件位置
文件名问题
注:配置文件位置和文件名称可以同时自定义。(对于 application.properties 而言,它不一定非要叫 application ,项目默认是去加载名为 application 的配置文件,如果配置文件不叫 application ,也是可以的,需要明确指定配置文件的文件名。)
普通的属性注入
由于 Spring Boot 中,默认会自动加载 application.properties 文件,所以简单的属性注入可以直接在这个配置文件中写。
book.name=计算机技术
book.author=张三
book.id=1
可以直接通过 @Value 注解将这些属性注入到 Book 对象中。
@Component
public class Book {
@Value("${book.id}")
private Long id;
@Value("${book.name}")
private String name;
@Value("${book.author}")
private String author;
//省略getter/setter
}
@RestController
public class HelloController {
@Autowired
Book book;
@GetMapping("/book")
public String book() {
System.out.println(book);
return "book";
}
}
配置完成后,在 Controller 或者单元测试中注入 Book 对象,启动项目,就可以看到属性已经注入到对象中了。
类型安全的属性注入
Spring Boot 引入了类型安全的属性注入,如果采用 Spring 中的配置方式,当配置的属性非常多的时候,工作量就很大了,而且容易出错。
@Component
@PropertySource("classpath:book.properties")
@ConfigurationProperties(prefix = "book")
public class Book {
private Long id;
private String name;
private String author;
//省略getter/setter
}
引入 @ConfigurationProperties(prefix = “book”) 注解,并且配置了属性的前缀,此时会自动将 Spring 容器中对应的数据注入到对象对应的属性中,就不用通过 @Value 注解挨个注入了,减少工作量并且避免出错。
总结
application.properties 是 Spring Boot 中配置的一个重要载体,一般来说,我们在 application.properties 文件中主要存放系统配置,很多组件的属性都可以在这里定制。
该文章内容是江南一点雨的内容,我只是为了记录学习、自己手写了才不会忘记,才写文章,如侵权请联系我。