Spring Boot中@Value加载配置的替代者:@ConfigurationProperties

@Value注解Spring Boot开发者都已经熟悉了,通过该注解,我们可以快速的把配置信息加载到Spring的Bean中。

例如:在application.yml中添加了一个配置如下:

我想在service中获取name,通过@value注解方式实现,代码如下:

这个注解用起来没有毛病,甚至还可以说挺好用,但是! 推荐更优秀的注解来替代它的核心原因是:当我们使用@Value来直接提取配置信息使用的时候,会产生配置信息加载的碎片化。比如,同一个配置,可能在多个Service或者Controller使用,当我们再要修改配置文件中的key的时候,可能会因为需要修改的地方太多遗漏而出现数据问题。

所以,现在推荐一个更好用的注解 @ConfigurationProperties 来替代value注解加载各种配置,具体配置如下:

上面的例子是 我想拿到配置中的name和age,通过@ConfigurationProperties注解设置前缀

复制代码
com.xiaoxingxing即可。

在代码中的实现;注入到具体需要使用的service然后获取对应数据即可。

延申: 校验字段可以使用 @Validated 字段,具体代码如下:

比如:我想让name非空 ,但是我在配置文件中去掉了name,这时启动报错,提示name不能为空

相关推荐
小江的记录本1 小时前
【Spring全家桶】Spring Cloud 2023.0.x:微服务核心理论、CAP/BASE定理(附《思维导图》+《面试高频考点清单》)
java·spring boot·后端·spring·spring cloud·微服务·面试
Solis程序员1 小时前
缓存三剑客预防策略
java·spring·缓存
我登哥MVP1 小时前
Spring Boot 从“会用”到“精通”:Model-Map原理
java·spring boot·后端·spring·servlet·maven·mybatis
程序猿乐锅1 小时前
【苍穹外卖|Day02】后台接口自测闭环:Token、DTO 与 yml 配置
java·开发语言
心之伊始1 小时前
Spring Boot Actuator + Micrometer 自定义业务指标:不只是健康检查
java·架构·源码分析·csdn
Eason_LYC1 小时前
【GetShell 实战】CVE-2026-34486 Tomcat 加密拦截器绕过:从漏洞验证到反弹 Shell 全流程
java·渗透测试·tomcat·java反序列化·rce·远程代码执行漏洞·cve-2026-34486
qq_2518364571 小时前
基于java 税务管理系统设计与实现
java·开发语言
超梦dasgg1 小时前
Java 生产环境分布式定时任务全解(实战落地版)
java·开发语言·分布式
破土士V2 小时前
Java基础知识集合
java·开发语言