Spring @Configuration 注解详解:用 Java 代码替代 XML 配置

简介: `@Configuration` 是 Spring 实现 Java 配置的核心注解,替代传统 XML,通过 `@Bean` 注册 Bean,结合 `@Import`、`@ComponentScan` 等实现类型安全、可维护的配置方式,推动 Spring 应用现代化。


在 Spring 框架中,传统的 Bean 管理依赖于 applicationContext.xml 等 XML 配置文件。随着 Spring 对注解和 Java 配置的支持日益完善,基于 Java 的配置方式已成为主流。其中,@Configuration 注解是实现这一转变的核心。


一、什么是 @Configuration

@Configuration 标注的类,会被 Spring 的 IOC 容器识别为一个配置类(Configuration Class),其作用等同于一个 XML 配置文件。在这个类中,你可以通过 @Bean 方法声明并注册 Spring 容器管理的 Bean。

示例:定义配置类
@Configuration
public class ConfigurationDemo {
    
    @Bean
    public Date currentDate() {
        return new Date();
    }
}

✅ 上述代码等价于以下 XML 配置:

<bean id="currentDate" class="java.util.Date"/>
  • 方法名 currentDate 默认作为 Bean 的名称(id);
  • 返回值对象由 Spring 容器管理,具备单例、依赖注入等特性。

二、启动基于 Java 配置的 IOC 容器

使用 AnnotationConfigApplicationContext 加载配置类,即可初始化 Spring 容器:

public class MainApp {
    public static void main(String[] args) {
        // 加载 ConfigurationDemo 配置类
        AnnotationConfigApplicationContext ctx = 
            new AnnotationConfigApplicationContext(ConfigurationDemo.class);
        
        // 打印容器中所有 Bean 的名称
        String[] beanNames = ctx.getBeanDefinitionNames();
        Arrays.stream(beanNames).forEach(System.out::println);
    }
}
输出结果:
org.springframework.context.annotation.internalConfigurationAnnotationProcessor
org.springframework.context.annotation.internalAutowiredAnnotationProcessor
org.springframework.context.annotation.internalCommonAnnotationProcessor
org.springframework.context.event.internalEventListenerProcessor
org.springframework.context.event.internalEventListenerFactory
configurationDemo
currentDate

🔍 关键说明

  • configurationDemo:配置类本身的 Bean(默认首字母小写);
  • currentDate:通过 @Bean 方法注册的自定义 Bean;
  • 其余为 Spring 内部自动注册的后处理器(如处理 @Autowired@EventListener 等)。

三、@Configuration 的核心特性

  1. 替代 XML 配置
    无需编写 <beans> 文件,全部配置通过 Java 代码完成,类型安全、易于重构。
  2. 支持依赖注入与方法调用
    在配置类内部,可通过方法调用实现 Bean 之间的依赖关系(得益于 CGLIB 代理):
@Configuration
public class AppConfig {
    @Bean
    public UserService userService() {
        return new UserService(userRepository()); // 直接调用另一个 @Bean 方法
    }
    @Bean
    public UserRepository userRepository() {
        return new UserRepository();
    }
}

⚠️ 注意:这种调用会经过 Spring 代理,确保返回的是容器中的单例 Bean,而非新实例。

  1. 可组合与导入
    使用 @Import 可将多个配置类组合:
@Configuration
@Import({DatabaseConfig.class, WebConfig.class})
public class RootConfig { }
  1. 与组件扫描结合
    配合 @ComponentScan,可同时管理配置类和注解驱动的组件(如 @Service@Repository):
@Configuration
@ComponentScan("com.example.service")
public class AppConfig { }

四、最佳实践建议

  • 命名规范:配置类建议以 ConfigConfiguration 结尾,如 DataSourceConfig
  • 职责单一:按功能拆分配置类(如数据库、缓存、Web),避免“上帝配置类”;
  • 优先使用 Java 配置:相比 XML,Java 配置更安全、可调试、支持 IDE 自动补全;
  • 避免在 @Bean 方法中使用 new 外部依赖:应通过参数注入或调用其他 @Bean 方法获取依赖。

总结

@Configuration 是 Spring 实现“无 XML”配置的关键注解。它让开发者能够以类型安全、结构清晰、易于维护的方式构建 Spring 应用上下文。结合 @Bean@Import@ComponentScan 等注解,你可以完全告别 XML,拥抱现代化的 Spring 开发体验。


相关文章
|
Java Maven
IDEA + maven 零基础构建 java agent 项目
Java Agent(java 探针)虽说在 jdk1.5 之后就有了,但是对于绝大多数的业务开发 javaer 来说,这个东西还是比较神奇和陌生的;虽说在实际的业务开发中,很少会涉及到 agent 开发,但是每个 java 开发都用过,比如使用 idea 写了个 HelloWorld.java,并运行一下, 仔细看控制台输出
1221 0
IDEA + maven 零基础构建 java agent 项目
|
5月前
|
JSON 搜索推荐 机器人
直播间自动发言机器人,抖音快手小红书哔哩哔哩机器人, 自动评论app机器人打字弹幕脚本
多平台支持:整合抖音、哔哩哔哩等平台的自动化操作 智能评论生成:结合视频内容动态生成个性化评论
|
数据挖掘 Python
【Python】已解决:Python pandas读取Excel表格某些数值字段结果为NaN问题
【Python】已解决:Python pandas读取Excel表格某些数值字段结果为NaN问题
1581 0
|
存储 Java
java用modbus4j的RTU去操作那些寄存器(线圈,保持,输入,离散输入寄存器)
java用modbus4j的RTU去操作那些寄存器(线圈,保持,输入,离散输入寄存器)
1071 0
|
缓存 关系型数据库 MySQL
Java 实现实时监听MySQL数据库变更MySQLBinListener
Java 实现实时监听MySQL数据库变更MySQLBinListener
|
Python
深入理解Python中的类方法、类实例方法和静态方法
深入理解Python中的类方法、类实例方法和静态方法
569 0
|
XML Java 测试技术
详细讲解Spring中的@Bean注解
详细讲解Spring中的@Bean注解
1427 0
详细讲解Spring中的@Bean注解
|
Python
Python编程:pypdf2和pdfplumber获取pdf文件的页数
Python编程:pypdf2和pdfplumber获取pdf文件的页数
815 0