SpringBoot @ConfigurationProperties注解的简单使用
作者:WinterJay
即便现在简化了配置,但是一个独立的配置文件总是易于理解而且使人安心的。Spring在构建完项目后,会默认在resources文件夹下创建一个application.properties文件,application.yml也是一样的效果。@ConfigurationProperties可以获取配置文件中的数据,将其注入类。
源码
@Target({ElementType.TYPE, ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface ConfigurationProperties { @AliasFor("prefix") String value() default ""; @AliasFor("value") String prefix() default ""; boolean ignoreInvalidFields() default false; boolean ignoreUnknownFields() default true; }
使用
向注解中传入配置文件中的前缀名,如果配置文件如下:
myConfigs: config1: field1: f1 field2: f2 field3: f3
那么代码中的配置类应该这样写:
@Component @ConfigurationProperties("myConfigs.config1") public class MyConfig1 { String field1; String field2; String field3; }
如上所示,field1, field2, field3三个属性就被绑定到了对象上。
注意到我们使用了@Component,实际上我们使用配置类都是将其注入到其他类中,所以我们往往将其注册为Bean。
ignoreInvalidFields默认为false,不合法的属性的属性会默认抛出异常;
ignoreUnknownFields默认为true, 未能识别的属性会被忽略(所以打错了名字就会被忽略了)
@ConfigurationProperties(prefix="config.prefix", ignoreInvalidFields=true, ignoreUnknownFields=false) public class MyConfig { // fields }
Spring Boot的绑定规则相当宽松,myField, my-field, my_field等都能识别绑定到myField上。
可以给字段设定默认值,这样配置中没有传入时会使用默认值。
@ConfigurationProperties("your.prefix") public class YourConfig { private String field = "Default" // setter }
类的字段必须要有public访问权限的setter方法。
在很多情况下public的setter方法时必须的,使用IDEA的话,这里推荐Alt+Insert(Windows, Mac使用Alt+n)生成;当然,想使用Lombok也可以
以上就是SpringBoot @ConfigurationProperties注解的简单使用的详细内容,更多关于SpringBoot @ConfigurationProperties注解的资料请关注脚本之家其它相关文章!
您可能感兴趣的文章:
- SpringBoot中的@ConfigurationProperties注解解析
- SpringBoot中@ConfigurationProperties注解的使用与源码详解
- 关于SpringBoot的@ConfigurationProperties注解和松散绑定、数据校验
- SpringBoot2底层注解@ConfigurationProperties配置绑定
- SpringBoot中@ConfigurationProperties注解实现配置绑定的三种方法
- SpringBoot中注解@ConfigurationProperties与@Value的区别与使用详解
- Springboot之@ConfigurationProperties注解解读