SpringBoot自动装配注解的实现示例

 更新时间:2026年04月01日 10:23:44   作者:kevinzeng  
本文主要介绍了SpringBoot自动装配注解的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

这份指南详细整理了 Spring Boot 中最核心的配置绑定自动装配以及条件注解。这些注解是理解 Spring Boot "约定大于配置" (Convention over Configuration) 机制的基石。

本文档详细解析 Spring Boot 中用于配置绑定、自动装配流程控制及条件加载的核心注解。

1. 配置属性绑定 (Configuration Binding)

这一组注解的主要作用是将 application.yml 或 application.properties 中的配置值绑定到 Java Bean 中。

@ConfigurationProperties

  • 用途:将配置文件中指定前缀的属性值自动绑定到 Java 类的字段上。
  • 关键点:
    • 仅仅加上这个注解,Spring 容器并不会自动注册它。它需要配合 @EnableConfigurationProperties 或 @Component (配合扫描) 使用。
    • 支持松散绑定 (Relaxed Binding),例如 first-name 可以绑定到 firstName。

@EnableConfigurationProperties

  • 用途:显式地开启 @ConfigurationProperties 注解类的功能,并将该类注册为 Spring Bean。
  • 场景:通常用在 @Configuration 类上,用于引入第三方的配置类,或者当你不想在配置类上加 @Component 时使用。

@ConfigurationPropertiesScan

  • 用途:从 Spring Boot 2.2 开始引入。它会扫描指定包路径下所有标注了 @ConfigurationProperties 的类,并自动注册为 Bean。
  • 优势:省去了在配置类上写一堆 @EnableConfigurationProperties({A.class, B.class}) 的麻烦。

📝 代码示例

1. 配置文件 (application.yml)

app:
  server:
    timeout: 5000
    enabled: true

2. 配置类 POJO

import org.springframework.boot.context.properties.ConfigurationProperties;
// 声明前缀,Spring 会去查找 app.server.*
@ConfigurationProperties(prefix = "app.server")
public class ServerProperties {
    private Integer timeout;
    private boolean enabled;
    // 必须要有 Getter/Setter
    public Integer getTimeout() { return timeout; }
    public void setTimeout(Integer timeout) { this.timeout = timeout; }
    public boolean isEnabled() { return enabled; }
    public void setEnabled(boolean enabled) { this.enabled = enabled; }
}

3. 启用配置 (三种方式选其一)

  • 方式 A:配合 @Component (最简单)

    • ServerProperties 上直接加 @Component,配合 @ConfigurationProperties
  • 方式 B:使用 @EnableConfigurationProperties (推荐用于库开发)

    @Configuration
    @EnableConfigurationProperties(ServerProperties.class)
    public class MyConfig { ... }
  • 方式 C:使用 @ConfigurationPropertiesScan (适合大型项目)

    @SpringBootApplication
    @ConfigurationPropertiesScan("com.example.config") // 扫描指定包
    public class MyApplication { ... }

2. 自动装配核心 (Auto Configuration)

@EnableAutoConfiguration

  • 用途:Spring Boot 的魔法核心。它告诉 Spring Boot 根据添加的 jar 依赖自动配置 Spring 应用。

  • 原理:

    • 它利用 SpringFactoriesLoader 机制。
    • 扫描 classpath 下所有 jar 包中的 META-INF/spring.factories (Spring Boot 2.x) 或 META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports (Spring Boot 3.x)。
    • 加载其中声明的配置类,但在加载前会通过 @Conditional 系列注解进行过滤。
  • 注意:通常包含在 @SpringBootApplication 中,很少单独使用。

3. 条件注解 (Conditionals)

这一组注解决定了 Bean 是否会被创建并注册到容器中。这是实现“自动装配”逻辑判断的关键。

@Conditional

  • 用途:最底层的注解。它接收一个实现了 Condition 接口的类。只有当 matches 方法返回 true 时,Bean 才会被创建。
  • 场景:编写非常复杂的自定义逻辑判断时使用。

@ConditionalOnProperty

  • 用途:这是 @Conditional 的扩展,专门用于判断配置文件中是否存在某个属性,或该属性的值是否等于特定值。

  • 常用属性:

    • prefix: 属性前缀。
    • name: 属性名。
    • havingValue: 期望的值(如果匹配则加载)。
    • matchIfMissing: 如果配置文件中没写这个属性,默认是否加载(true 为加载)。

📝 代码示例:基于配置开关功能的 Bean

假设我们根据配置决定启用 "短信通知" 还是 "邮件通知"。

1. 配置文件

feature:
  notification: sms  # 改为 email 则加载 EmailService

2. 业务 Bean 定义

import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class NotificationConfig {
    @Bean
    // 当 feature.notification = email 时生效
    @ConditionalOnProperty(prefix = "feature", name = "notification", havingValue = "email")
    public NotificationService emailService() {
        return new EmailNotificationService();
    }
    @Bean
    // 当 feature.notification = sms 时生效
    // matchIfMissing = true 表示如果不配这个配置,默认也启用 SMS
    @ConditionalOnProperty(prefix = "feature", name = "notification", havingValue = "sms", matchIfMissing = true)
    public NotificationService smsService() {
        return new SmsNotificationService();
    }
}

📝 代码示例:自定义 @Conditional (高阶用法)

如果 @ConditionalOnProperty 无法满足需求(比如判断操作系统、判断某个文件是否存在),可以使用 @Conditional

// 1. 定义判断逻辑
public class WindowsCondition implements Condition {
    @Override
    public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {
        return context.getEnvironment().getProperty("os.name").contains("Windows");
    }
}
// 2. 使用注解
@Bean
@Conditional(WindowsCondition.class) // 只有在 Windows 系统下才加载该 Bean
public CmdService cmdService() {
    return new WindowsCmdService();
}

4. 总结速查表

注解作用域核心作用一句话记忆
@ConfigurationProperties定义配置属性与 POJO 的映射"把 yml 变成 Java 对象"
@EnableConfigurationProperties配置类激活并注册 @ConfigurationProperties 类"手动开关:启用属性对象"
@ConfigurationPropertiesScan启动类自动扫描并注册属性类"自动开关:扫码全注册"
@EnableAutoConfiguration启动类开启自动装配机制 (SPI)"Spring Boot 的自动魔法引擎"
@Conditional方法/类自定义复杂的加载条件"万能的 if 判断"
@ConditionalOnProperty方法/类基于配置属性值决定是否加载 Bean"根据开关 (Toggle) 加载 Bean"

到此这篇关于SpringBoot自动装配注解的实现示例的文章就介绍到这了,更多相关SpringBoot自动装配注解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot使用LibreOffice实现高保真Word转PDF的方法

    SpringBoot使用LibreOffice实现高保真Word转PDF的方法

    本文介绍了在SpringBoot中使用LibreOffce实现高保真Word转PDF的方法,首先详细说明了Windows、Mac、Linux系统及Docker环境下LibreOffice的安装步骤和常见问题解决方案,需要的朋友可以参考下
    2026-02-02
  • idea连接数据库的操作方法

    idea连接数据库的操作方法

    这篇文章主要介绍了idea如何连接数据库,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2024-02-02
  • Java编写日志手机号脱敏工具类

    Java编写日志手机号脱敏工具类

    在开发过程中,很容易将用户敏感信息,例如手机号码、身份证等,打印在日志平台,本文将利用Java编写一个日志手机号脱敏工具类,感兴趣的可以了解下
    2024-12-12
  • Springboot的启动原理详细解读

    Springboot的启动原理详细解读

    这篇文章主要介绍了Springboot的启动原理详细解读,springboot项目一般都是打包成jar包直接运行main方法启动,当然也可以跟传统的项目一样打包war包放在tomcat里面启动.那么springboot怎么直接通过main方法启动呢,需要的朋友可以参考下
    2023-11-11
  • SpringBoot整合MongoDB实现文件上传下载删除

    SpringBoot整合MongoDB实现文件上传下载删除

    这篇文章主要介绍了SpringBoot整合MongoDB实现文件上传下载删除的方法,帮助大家更好的理解和学习使用SpringBoot框架,感兴趣的朋友可以了解下
    2021-05-05
  • SpringCloud Eureka服务注册与发现实践

    SpringCloud Eureka服务注册与发现实践

    本文介绍了Eureka的基本概念、服务注册与发现流程、单机和集群搭建方法,以及心跳续约和自我保护机制,通过实际操作和测试,验证了Eureka在微服务架构中的重要性和可靠性
    2026-03-03
  • Java中数组的常见操作合集

    Java中数组的常见操作合集

    这篇文章主要为大家详细介绍了Java中数组的一些常见操作,例如:数组遍历、数组获取最大值元素、数组反转等,感兴趣的小伙伴可以了解一下
    2022-10-10
  • Java多线程并发的指令重排序问题及volatile写屏障原理详解

    Java多线程并发的指令重排序问题及volatile写屏障原理详解

    这篇文章主要介绍了Java多线程并发的指令重排序问题及volatile写屏障原理详解,指令重排序是编译器或处理器为了提高性能而对指令执行顺序进行重新排列的优化技术,需要的朋友可以参考下
    2024-01-01
  • SpringBoot2.x 参数校验问题小结

    SpringBoot2.x 参数校验问题小结

    这篇文章主要介绍了SpringBoot2.x 参数校验一些问题总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • java 对文件夹目录进行深度遍历实例代码

    java 对文件夹目录进行深度遍历实例代码

    这篇文章主要介绍了java 对文件夹目录进行深度遍历实例代码的相关资料,需要的朋友可以参考下
    2017-03-03

最新评论