[关闭]
@MRsunhuimin 2020-07-29T13:36:17.000000Z 字数 8422 阅读 151

SpringBoot 注解

SpringBoot

作者:孙慧敏

https://www.cnblogs.com/wudimanong/p/10457211.html
https://blog.csdn.net/weixin_40753536/article/details/81285046
https://blog.csdn.net/fz13768884254/article/details/83538709

1. Spring相关注解

1. @Configuration

    从Spring3.0,@Configuration用于定义配置类,可替换xml配置文件,被注解的类内部包含有一个或多个被@Bean注解的方法,这些方法将会被AnnotationConfigApplicationContext或AnnotationConfigWebApplicationContext类进行扫描,并用于构建bean定义,初始化Spring容器。
  1. @Configuration
  2. public class TaskAutoConfiguration {
  3. @Bean
  4. @Profile("biz-electrfence-controller")
  5. public BizElectrfenceControllerJob bizElectrfenceControllerJob() {
  6. return new BizElectrfenceControllerJob();
  7. }
  8. @Bean
  9. @Profile("biz-consume-1-datasync")
  10. public BizBikeElectrFenceTradeSyncJob bizBikeElectrFenceTradeSyncJob() {
  11. return new BizBikeElectrFenceTradeSyncJob();
  12. }
  13. }

2. @ComponentScan

    做过web开发的同学一定都有用过@Controller,@Service,@Repository注解,查看其源码你会发现,他们中有一个共同的注解@Component,没错@ComponentScan注解默认就会装配标识了@Controller,@Service,@Repository,@Component注解的类到spring容器中。
  1. @ComponentScan(value = "com.abacus.check.api")
  2. public class CheckApiApplication {
  3. public static void main(String[] args) {
  4. SpringApplication.run(CheckApiApplication.class, args);
  5. }
  6. }
    @SpringBootApplication注解也包含了@ComponentScan注解,所以在使用中我们也可以通过@SpringBootApplication注解的scanBasePackages属性进行配置。
  1. @SpringBootApplication(scanBasePackages = {"com.abacus.check.api", "com.abacus.check.service"})
  2. public class CheckApiApplication {
  3. public static void main(String[] args) {
  4. SpringApplication.run(CheckApiApplication.class, args);
  5. }
  6. }

3. @Conditional

    @Conditional是Spring4新提供的注解,通过@Conditional注解可以根据代码中设置的条件装载不同的bean,在设置条件注解之前,先要把装载的bean类去实现Condition接口,然后对该实现接口的类设置是否装载的条件。Spring Boot注解中的@ConditionalOnProperty、@ConditionalOnBean等以@Conditional*开头的注解,都是通过集成了@Conditional来实现相应功能的。

4. @Import

    通过导入的方式实现把实例加入springIOC容器中。可以在需要时将没有被Spring容器管理的类导入至Spring容器中。
  1. //类定义
  2. public class Square {}
  3. public class Circular {}
  4. //导入
  5. @Import({Square.class,Circular.class})
  6. @Configuration
  7. public class MainConfig{}

5. @ImportResource

    和@Import类似,区别就是@ImportResource导入的是配置文件。
  1. @ImportResource("classpath:spring-redis.xml") //导入xml配置
  2. public class CheckApiApplication {
  3. public static void main(String[] args) {
  4. SpringApplication.run(CheckApiApplication.class, args);
  5. }
  6. }

6. @Component

    @Component是一个元注解,意思是可以注解其他类注解,如@Controller @Service @Repository。带此注解的类被看作组件,当使用基于注解的配置和类路径扫描的时候,这些类就会被实例化。其他类级别的注解也可以被认定为是一种特殊类型的组件,比如@Controller 控制器(注入服务)、@Service服务(注入dao)、@Repository dao(实现dao访问)。@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注,作用就相当于 XML配置,<bean id="" class=""/>。

2. SpringBoot相关注解

1. @SpringBootApplication

    这个注解是Spring Boot最核心的注解,用在 Spring Boot的主类上,标识这是一个 Spring Boot 应用,用来开启 Spring Boot 的各项能力。实际上这个注解是@Configuration,@EnableAutoConfiguration,@ComponentScan三个注解的组合。由于这些注解一般都是一起使用,所以Spring Boot提供了一个统一的注解@SpringBootApplication。
  1. @SpringBootApplication(exclude = {
  2. MongoAutoConfiguration.class,
  3. MongoDataAutoConfiguration.class,
  4. DataSourceAutoConfiguration.class,
  5. ValidationAutoConfiguration.class,
  6. MybatisAutoConfiguration.class,
  7. MailSenderAutoConfiguration.class,
  8. })
  9. public class API {
  10. public static void main(String[] args) {
  11. SpringApplication.run(API.class, args);
  12. }
  13. }

2. @EnableAutoConfiguration

    允许 Spring Boot 自动配置注解,开启这个注解之后,Spring Boot 就能根据当前类路径下的包或者类来配置 Spring Bean。

    如:当前类路径下有 Mybatis 这个 JAR 包,MybatisAutoConfiguration 注解就能根据相关参数来配置 Mybatis 的各个 Spring Bean。

    @EnableAutoConfiguration实现的关键在于引入了AutoConfigurationImportSelector,其核心逻辑为selectImports方法,逻辑大致如下:

    从配置文件META-INF/spring.factories加载所有可能用到的自动配置类;

    去重,并将exclude和excludeName属性携带的类排除;

    过滤,将满足条件(@Conditional)的自动配置类返回;
  1. @Target({ElementType.TYPE})
  2. @Retention(RetentionPolicy.RUNTIME)
  3. @Documented
  4. @Inherited
  5. @AutoConfigurationPackage//导入AutoConfigurationImportSelector的子类@Import({EnableAutoConfigurationImportSelector.class})
  6. public @interface EnableAutoConfiguration {
  7. String ENABLED_OVERRIDE_PROPERTY = "spring.boot.enableautoconfiguration";
  8. Class<?>[] exclude() default {};
  9. String[] excludeName() default {};
  10. }

3. @SpringBootConfiguration3

    这个注解就是 @Configuration 注解的变体,只是用来修饰是 Spring Boot 配置而已,或者可利于 Spring Boot 后续的扩展。

4. @ConditionalOnBean

    @ConditionalOnBean(A.class)仅仅在当前上下文中存在A对象时,才会实例化一个Bean,也就是说只有当A.class 在spring的applicationContext中存在时,这个当前的bean才能够创建。
  1. @Bean
  2. //当前环境上下文存在DefaultMQProducer实例时,才能创建RocketMQProducerLifecycle这个Bean
  3. @ConditionalOnBean(DefaultMQProducer.class)
  4. public RocketMQProducerLifecycle rocketMQLifecycle() {
  5. return new RocketMQProducerLifecycle();
  6. }

5. @ConditionalOnMissingBean

    组合@Conditional注解,和@ConditionalOnBean注解相反,仅仅在当前上下文中不存在A对象时,才会实例化一个Bean。
  1. @Bean
  2. //仅当当前环境上下文缺失RocketMQProducer对象时,才允许创建RocketMQProducer Bean对象
  3. @ConditionalOnMissingBean(RocketMQProducer.class)
  4. public RocketMQProducer mqProducer() {
  5. return new RocketMQProducer();
  6. }

6. @ConditionalOnClass

    组合 @Conditional 注解,可以仅当某些类存在于classpath上时候才创建某个Bean。
  1. @Bean
  2. //当classpath中存在类HealthIndicator时,才创建HealthIndicator Bean对象
  3. @ConditionalOnClass(HealthIndicator.class)
  4. public HealthIndicator rocketMQProducerHealthIndicator(Map<String, DefaultMQProducer> producers) {
  5. if (producers.size() == 1) {
  6. return new RocketMQProducerHealthIndicator(producers.values().iterator().next());
  7. }
  8. }

7. @ConditionalOnMissingClass

    组合@Conditional注解,和@ConditionalOnMissingClass注解相反,当classpath中没有指定的 Class才开启配置。

8. @ConditionalOnWebApplication

    组合@Conditional 注解,当前项目类型是 WEB 项目才开启配置。当前项目有以下 3 种类型:ANY(任何Web项目都匹配)、SERVLET(仅但基础的Servelet项目才会匹配)、REACTIVE(只有基于响应的web应用程序才匹配)。

9. @ConditionalOnNotWebApplication

    组合@Conditional注解,和@ConditionalOnWebApplication 注解相反,当前项目类型不是 WEB 项目才开启配置。

10. @ConditionalOnProperty

    组合 @Conditional 注解,当指定的属性有指定的值时才开启配置。具体操作是通过其两个属性name以及havingValue来实现的,其中name用来从application.properties中读取某个属性值,如果该值为空,则返回false;如果值不为空,则将该值与havingValue指定的值进行比较,如果一样则返回true;否则返回false。如果返回值为false,则该configuration不生效;为true则生效。
  1. @Bean
  2. //匹配属性rocketmq.producer.enabled值是否为true
  3. @ConditionalOnProperty(value = "rocketmq.producer.enabled", havingValue = "true", matchIfMissing = true)
  4. public RocketMQProducer mqProducer() {
  5. return new RocketMQProducer();
  6. }

11. @ConditionalOnExpression

    组合 @Conditional 注解,当 SpEL 表达式为 true 时才开启配置。
  1. @Configuration
  2. @ConditionalOnExpression("${enabled:false}")
  3. public class BigpipeConfiguration {
  4. @Bean
  5. public OrderMessageMonitor orderMessageMonitor(ConfigContext configContext) {
  6. return new OrderMessageMonitor(configContext);
  7. }
  8. }

12. @ConditionalOnJava

    组合@Conditional 注解,当运行的 Java JVM 在指定的版本范围时才开启配置。

13. @ConditionalOnResource

    组合 @Conditional 注解,当类路径下有指定的资源才开启配置。
  1. @Bean
  2. @ConditionalOnResource(resources="classpath:shiro.ini")
  3. protected Realm iniClasspathRealm(){
  4. return new Realm();
  5. }

14. @ConditionalOnJndi

    组合 @Conditional 注解,当指定的 JNDI 存在时才开启配置。

15. @ConditionalOnCloudPlatform

    组合 @Conditional 注解,当指定的云平台激活时才开启配置。

16. @ConditionalOnSingleCandidate

    组合 @Conditional 注解,当指定的 class 在容器中只有一个 Bean,或者同时有多个但为首选时才开启配置。

17. @ConfigurationProperties

    Spring Boot可使用注解的方式将自定义的properties文件映射到实体bean中,比如config.properties文件。

@Data
@ConfigurationProperties("rocketmq.consumer")
public class RocketMQConsumerProperties extends RocketMQProperties {
private boolean enabled = true;

private String consumerGroup;

private MessageModel messageModel = MessageModel.CLUSTERING;

private ConsumeFromWhere consumeFromWhere = ConsumeFromWhere.CONSUME_FROM_LAST_OFFSET;

private int consumeThreadMin = 20;

private int consumeThreadMax = 64;

private int consumeConcurrentlyMaxSpan = 2000;

private int pullThresholdForQueue = 1000;

private int pullInterval = 0;

private int consumeMessageBatchMaxSize = 1;

private int pullBatchSize = 32;

}

  1. ###18. @EnableConfigurationProperties
  2. @EnableConfigurationProperties注解应用到你的@Configuration时,任何被@ConfigurationProperties注解的beans将自动被Environment属性配置。 这种风格的配置特别适合与SpringApplication的外部YAML配置进行配合使用。
  3. ```java
  4. @Configuration
  5. @EnableConfigurationProperties({
  6. RocketMQProducerProperties.class,
  7. RocketMQConsumerProperties.class,
  8. })
  9. @AutoConfigureOrder
  10. public class RocketMQAutoConfiguration {
  11. @Value("${spring.application.name}")
  12. private String applicationName;
  13. }
  14. <div class="md-section-divider"></div>

19. @AutoConfigureAfter

    用在自动配置类上面,表示该自动配置类需要在另外指定的自动配置类配置完之后。

    如 Mybatis 的自动配置类,需要在数据源自动配置类之后。
  1. @AutoConfigureAfter(DataSourceAutoConfiguration.class)
  2. public class MybatisAutoConfiguration {
  3. }
  4. <div class="md-section-divider"></div>

20. @AutoConfigureBefore

    这个和@AutoConfigureAfter注解使用相反,表示该自动配置类需要在另外指定的自动配置类配置之前。

21. @AutoConfigureOrder

    Spring Boot 1.3.0中有一个新的注解@AutoConfigureOrder,用于确定配置加载的优先级顺序。
  1. @AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE) // 自动配置里面的最高优先级
  2. @Configuration
  3. @ConditionalOnWebApplication // 仅限于web应用
  4. @Import(BeanPostProcessorsRegistrar.class) // 导入内置容器的设置
  5. public class EmbeddedServletContainerAutoConfiguration {
  6. @Configuration
  7. @ConditionalOnClass({ Servlet.class, Tomcat.class })
  8. @ConditionalOnMissingBean(value = EmbeddedServletContainerFactory.class, search = SearchStrategy.CURRENT)
  9. public static class EmbeddedTomcat {
  10. // ...
  11. }
  12. @Configuration
  13. @ConditionalOnClass({ Servlet.class, Server.class, Loader.class, WebAppContext.class })
  14. @ConditionalOnMissingBean(value = EmbeddedServletContainerFactory.class, search = SearchStrategy.CURRENT)
  15. public static class EmbeddedJetty {
  16. // ...
  17. }
  18. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注