@PropertySource&@ImportResource&@Bean

一、核心定义与基础用法

1. @Value 注解

@Value 是 Spring 中用于零散地、直接地注入单个配置值的注解,支持 SpEL 表达式(Spring 表达式语言),通常作用在字段、方法参数或构造器参数上。

java

运行

复制代码
@Component
public class ValueDemo {
    // 注入单个配置值
    @Value("${app.name}")
    private String appName;

    // 支持默认值
    @Value("${app.port:8080}")
    private Integer appPort;

    // 支持SpEL表达式
    @Value("#{T(java.lang.Math).random() * 100}")
    private Double randomNum;
}
2. @ConfigurationProperties 注解

@ConfigurationProperties 是 Spring Boot 提供的注解,用于批量地、结构化地 绑定一组相关的配置属性到一个 Java 类中,通常作用在类上,需要配合 @Component(或 @Configuration)使类被 Spring 管理。

java

运行

复制代码
@Component
// 绑定配置前缀为app的所有属性
@ConfigurationProperties(prefix = "app")
public class ConfigPropertiesDemo {
    private String name;
    private Integer port;
    private List<String> allowedIps; // 支持复杂类型(集合、对象)

    // 必须提供getter/setter方法(核心!)
    public String getName() { return name; }
    public void setName(String name) { this.name = name; }
    public Integer getPort() { return port; }
    public void setPort(Integer port) { this.port = port; }
    public List<String> getAllowedIps() { return allowedIps; }
    public void setAllowedIps(List<String> allowedIps) { this.allowedIps = allowedIps; }
}

对应的 application.yml 配置:

yaml

复制代码
app:
  name: demo-app
  port: 8081
  allowed-ips: [127.0.0.1, 192.168.1.1]

二、核心对比(笔记核心)

对比维度 @Value 注解 @ConfigurationProperties 注解
绑定方式 单个属性零散绑定 批量结构化绑定(按前缀分组)
支持的数据类型 基本类型、String、SpEL 表达式 基本类型、String、集合、对象(嵌套)
是否需要 getter/setter 不需要(直接注入字段) 必须需要(通过 setter 绑定)
默认值支持 支持(如 ${key:默认值} 不直接支持(需在类中手动设置默认值)
SpEL 表达式支持 支持 不支持
配置校验 不支持(无法用 @Validated 等校验) 支持(配合 @Validated、@NotNull 等)
松散绑定 不支持(必须严格匹配配置名,如 appName 不能写 app-name) 支持(app-name 可绑定到 appName 字段)
IDE 提示 无(IDE 无法识别配置键是否存在) 有(Spring Boot 插件可提示配置键)
使用场景 少量、零散的配置注入 一组相关的配置(如数据源、第三方服务配置)

三、实战示例:配置校验(@ConfigurationProperties 独有)

java

运行

复制代码
@Component
@ConfigurationProperties(prefix = "app")
@Validated // 开启校验
public class ValidConfigDemo {
    @NotNull(message = "应用名称不能为空") // 校验规则
    private String name;

    @Min(value = 1024, message = "端口号不能小于1024")
    private Integer port;

    // getter/setter省略
}

当配置中 app.name 为空时,启动项目会直接抛出校验异常,提前发现配置错误,这是 @Value 做不到的。

四、使用建议

  1. 如果只是注入 1-2 个零散的配置(如单个端口、单个开关),用 @Value 更简洁;
  2. 如果是一组相关的配置(如数据库配置:url、username、password),优先用 @ConfigurationProperties,可读性和可维护性更高;
  3. 对配置有校验需求、需要 IDE 提示、或配置包含集合 / 对象类型时,必须用 @ConfigurationProperties
  4. 避免混合使用:同一组配置要么全用 @Value,要么全用 @ConfigurationProperties,保持风格统一。

总结

  1. @Value 适合零散、简单、需 SpEL 的配置注入,无需 getter/setter,但不支持校验和松散绑定;
  2. @ConfigurationProperties 适合批量、结构化、需校验 的配置注入,支持复杂类型和松散绑定,是 Spring Boot 中管理配置的最佳实践;
  3. 核心选择依据:配置的 "关联性" 和 "复杂度"------ 零散简单用@Value,成组复杂用@ConfigurationProperties
相关推荐
HackTorjan4 小时前
深度神经网络的反向传播与梯度优化原理
人工智能·spring boot·神经网络·机器学习·dnn
直奔標竿14 小时前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring
敖正炀15 小时前
WebFlux 深度:Reactor 线程模型、背压与错误处理
spring boot
BING_Algorithm15 小时前
一文搞定 AOP 所有核心知识点
spring boot·后端·spring
勿忘初心122116 小时前
【Java实战】SpringBoot 集成 freemarker 导出 Word 模板
java·spring boot·freemarker·模板引擎·word导出·后端实战
绿草在线16 小时前
SpringBoot项目实战:从零搭建高效开发环境
java·spring boot·后端
空中海18 小时前
Spring Boot Kafka 项目 Demo:订单事件系统 专家知识、源码阅读路线与面试题
spring boot·kafka·linq
默 语2 天前
基于 Spring Boot 3 + LangChain4j 快速构建企业级 AI 应用实战
人工智能·spring boot·后端
薪火铺子2 天前
SpringBoot WebServer启动与监听器原理深度解析
spring boot·后端·tomcat
KmSH8umpK2 天前
SpringBoot 分布式锁实战:从单机锁到Redis分布式锁全覆盖,解决超卖、重复下单、幂等并发问题
spring boot·redis·分布式