SpringBoot中的@Configuration注解详解
写在前面
Spring Boot推荐使用JAVA配置来完全代替XML 配置,JAVA配置就是通过 @Configuration和 @Bean两个注解实现的
也就是说:@Configuration+@Bean可以达到在Spring中使用XML配置文件的作用
@Configuration可理解为使用Spring框架时的XML文件中的<beans/>
@Bean可理解为使用Spring框架时XML里面的<bean/>标签。
使用目的
@Configuration用于定义配置类,可替换xml配置文件,被注解的类内部包含有一个或多个被@Bean注解的方法
这些方法将会被AnnotationConfigWebApplicationContext或AnnotationConfigApplicationContext类进行扫描,并构建Bean定义,初始化Spring容器。
使用约束
- @Configuration注解作用在类、接口(包含注解)上
- @Configuration用于定义配置类,可替换XML配置文件,相当于XML形式的Spring配置
- @Configuration注解类中可以声明一个或多个 @Bean 注解的方法
- @Configuration注解作用的类不能是 final 类型
- @Configuration不可以是匿名类;
- 嵌套的 @Configuration类必须是 static 的
代码示例
package com.hadoopx.mallx.data.config.redis; import org.apache.commons.pool2.impl.GenericObjectPoolConfig; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisPassword; import org.springframework.data.redis.connection.RedisStandaloneConfiguration; import org.springframework.data.redis.connection.lettuce.LettuceClientConfiguration; import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory; import org.springframework.data.redis.connection.lettuce.LettucePoolingClientConfiguration; import org.springframework.data.redis.core.StringRedisTemplate; import java.time.Duration; @Configuration public class RedisAutoConfig { @Bean public LettuceConnectionFactory defaultLettuceConnectionFactory(RedisStandaloneConfiguration defaultRedisConfig, GenericObjectPoolConfig defaultPoolConfig) { LettuceClientConfiguration clientConfig = LettucePoolingClientConfiguration.builder().commandTimeout(Duration.ofMillis(5000)) .poolConfig(defaultPoolConfig).build(); return new LettuceConnectionFactory(defaultRedisConfig, clientConfig); } @Bean public StringRedisTemplate stringRedisTemplate(LettuceConnectionFactory defaultLettuceConnectionFactory) { StringRedisTemplate stringRedisTemplate = new StringRedisTemplate(); stringRedisTemplate.setConnectionFactory(defaultLettuceConnectionFactory); return stringRedisTemplate; } @Configuration public static class DefaultRedisConfig { /** * 获取配置文件中spring.redis.host的值, 如果没有则使用默认值: 127.0.0.1 * 使用如下: * @Value("${YML-KEY:DEFAULT-VALUE}") */ @Value("${spring.redis.host:127.0.0.1}") private String host; @Value("${spring.redis.port:6379}") private Integer port; @Value("${spring.redis.password:}") private String password; @Value("${spring.redis.database:0}") private Integer database; @Value("${spring.redis.lettuce.pool.max-active:8}") private Integer maxActive; @Value("${spring.redis.lettuce.pool.max-idle:8}") private Integer maxIdle; @Value("${spring.redis.lettuce.pool.max-wait:-1}") private Long maxWait; @Value("${spring.redis.lettuce.pool.min-idle:0}") private Integer minIdle; @Bean public GenericObjectPoolConfig defaultPoolConfig() { GenericObjectPoolConfig config = new GenericObjectPoolConfig(); config.setMaxTotal(maxActive); config.setMaxIdle(maxIdle); config.setMinIdle(minIdle); config.setMaxWaitMillis(maxWait); return config; } @Bean public RedisStandaloneConfiguration defaultRedisConfig() { RedisStandaloneConfiguration config = new RedisStandaloneConfiguration(); config.setHostName(host); config.setPassword(RedisPassword.of(password)); config.setPort(port); config.setDatabase(database); return config; } } }
基础运用
@Configuration注解最常见的搭配使用有两个:@Bean和@Scope
- @Bean:等价于Spring中的bean标签用于注册bean对象的,给容器中添加组件,一般以方法名作为组件的id,配置类里面使用@Bean标注在方法上给容器注册组件,默认是单实例的。
@Configuration(proxyBeanMethods = true) //告诉springboot这是一个配置类 == 配置文件 public class Myconfig { @Bean//给容器中添加组件,以方法名作为组件的id。 // 返回类型为组件类型,返回的值,就是组件在容器中的实例 public User user01(){ User wangcai = new User("wangcai",23); //user组件依赖了pet组件 wangcai.setPet(pet01()); return wangcai; } @Bean public Pet pet01(){ return new Pet("旺财"); } }
- @Scope:用于声明该bean的作用域,作用域有singleton、prototype、request、session。
@Configuration public class MyConfig { @Bean("user") @Scope(SCOPE_PROTOTYPE) //多例 public User getUser(){ System.out.println("User对象进行创建!"); return new User("用户", 22, getDog()); } @Bean("dog") @Scope(SCOPE_SINGLETON) //单例 public Dog getDog(){ System.out.println("Dog对象进行创建!"); return new Dog("金毛", 3); } }
@Configuration注解的属性
- @Configuration注解中有@Component注解的加持,因此它自己本身也是一个bean对象,可以通过Context的进行获取。
- @Configuration中的属性proxyBeanMethods是及其重要的,设置true/false会得到不同的效果。
- proxyBeanMethods = true的情况下,保持单实例对象
- proxyBeanMethods = false的情况下,不进行检查IOC容器中是否存在,而是简单的调用方法进行创建对象,无法保持单实例
- 简单来说,就相当于true只调用一次,而false会调用多次。
到此这篇关于SpringBoot中的@Configuration注解详解的文章就介绍到这了,更多相关@Configuration注解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解Spring Boot配置使用Logback进行日志记录的实战
本篇文章主要介绍了详解Spring Boot配置使用Logback进行日志记录的实战,具有一定的参考价值,有兴趣的朋友可以了解一下2017-07-07使用springboot单元测试对weblistener的加载测试
这篇文章主要介绍了使用springboot单元测试对weblistener的加载测试,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-10-10java String到底有多长?String超出长度该如何解决
在Java中,由于字符串常量池的存在,String常量长度限制取决于String常量在常量池中的存储大小,下面这篇文章主要给大家介绍了关于java String到底有多长?String超出长度该如何解决的相关资料,需要的朋友可以参考下2023-01-01
最新评论