导读

Boot方式的项目开发已经逐步成为Java应用开发领域的主流框架,它不仅可以方便地创建生产级的应用程序,还能轻松地通过一些注解配置与目前比较火热的微服务框架集成,

而 Boot 之所以能够轻松地实现应的创建及与其他框架快速集成,最核心的原因就在于它极大地简化了项目的配置,最大化地实现了“约定大于配置”的原则,然而基于 Boot 虽然极大地方便了开发,但是也很容易让人“云里雾里”,特别是各种注解很容易让人“知其然而不知其所以然”。

所以,要想用好 Boot 就必须对其提供的各类功能注解有一个全面而清晰地认识和理解。一方面可以提高基于 Boot 的开发效率,另外一方面也是面试中被问及框架原理时所必须掌握的知识点。在接下来的内容中,小编就带大家一起来探究下 Boot 的一些常用注解吧!

相关6个注解

Boot 的有些注解也需要与 的注解搭配使用,这里 怀玉 梳理了在项目中与 Boot 注解配合最为紧密的 6 个 基础框架的注解。如:

1、@

从.0,@用于定义配置类,可替换xml配置文件boot.ini文件,被注解的类内部包含有一个或多个被@Bean注解的方法,这些方法将会被或类进行扫描,并用于构建bean定义,初始化容器。

@Configuration
public class TaskAutoConfiguration {

    @Bean
    @Profile("biz-electrfence-controller")
    public BizElectrfenceControllerJob bizElectrfenceControllerJob() {
        return new BizElectrfenceControllerJob();
    }

    @Bean
    @Profile("biz-consume-1-datasync")
    public BizBikeElectrFenceTradeSyncJob bizBikeElectrFenceTradeSyncJob() {
        return new BizBikeElectrFenceTradeSyncJob();
    }
}

2、@

做过web开发的同学一定都有用过@,@,@注解,查看其源码你会发现,他们中有一个共同的注解@,没错@注解默认就会装配标识了@,@,@,@注解的类到容器中。

@ComponentScan(value = "com.abacus.check.api")
public class CheckApiApplication {
    public static void main(String[] args) {
        SpringApplication.run(CheckApiApplication.classargs);
    }
}

@n注解也包含了@注解,所以在使用中我们也可以通过@n注解的属性进行配置。

@SpringBootApplication(scanBasePackages = {"com.abacus.check.api""com.abacus.check.service"})
public class CheckApiApplication {
    public static void main(String[] args) {
        SpringApplication.run(CheckApiApplication.classargs);
    }
}

3、@

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

4、@

通过导入的方式实现把实例加入容器中。可以在需要时将没有被容器管理的类导入至容器中。

//类定义
public class Square {}

public class Circular {}

//导入
@Import({Square.class,Circular.class})
@Configuration
public class MainConfig
{}

5、@

和@类似,区别就是@导入的是配置文件。

@ImportResource("classpath:spring-redis.xml")      //导入xml配置

public class CheckApiApplication {
    public static void main(String[] args) {
        SpringApplication.run(CheckApiApplication.classargs);
    }
}

6、@

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

Boot 最核心的20个注解

说完与 Boot密切相关的几个基础注解后,下面我们就再一起看看 Boot提供的核心注解的内容吧!

1、@n

这个注解是 Boot最核心的注解,用在 Boot的主类上,标识这是一个 Boot 应用boot.ini文件,用来开启 Boot 的各项能力。实际上这个注解是@,@ion,@三个注解的组合。由于这些注解一般都是一起使用,所以 Boot提供了一个统一的注解@n。

@SpringBootApplication(exclude = {
        MongoAutoConfiguration.class,
        MongoDataAutoConfiguration.class,
        DataSourceAutoConfiguration.class,
        ValidationAutoConfiguration.class,
        MybatisAutoConfiguration.class,
        MailSenderAutoConfiguration.class,
})
public class API 
{
    public static void main(String[] args) {
        SpringApplication.run(API.classargs);
    }
}

2、@ion

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

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

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

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
//导入AutoConfigurationImportSelector的子类
@Import({EnableAutoConfigurationImportSelector.class})
public @interface EnableAutoConfiguration 
{
    String ENABLED_OVERRIDE_PROPERTY = "spring.boot.enableautoconfiguration";

    Class[] exclude() default {};

    String[] excludeName() default {};
}

3、@ion

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

4、@

@(A.class)仅仅在当前上下文中存在A对象时,才会实例化一个Bean,也就是说只有当A.class 在的中存在时,这个当前的bean才能够创建。

@Bean
//当前环境上下文存在DefaultMQProducer实例时,才能创建RocketMQProducerLifecycle这个Bean
@ConditionalOnBean(DefaultMQProducer.class)
public RocketMQProducerLifecycle rocketMQLifecycle() 
{
     return new RocketMQProducerLifecycle();
}

5、@Bean

组合@注解,和@注解相反,仅仅在当前上下文中不存在A对象时,才会实例化一个Bean

  @Bean
  //仅当当前环境上下文缺失RocketMQProducer对象时,才允许创建RocketMQProducer Bean对象
  @ConditionalOnMissingBean(RocketMQProducer.class)
  public RocketMQProducer mqProducer() 
{
      return new RocketMQProducer();
  }

6、@

组合 @ 注解,可以仅当某些类存在于上时候才创建某个Bean。

  @Bean
  //当classpath中存在类HealthIndicator时,才创建HealthIndicator Bean对象
  @ConditionalOnClass(HealthIndicator.class)
  public HealthIndicator rocketMQProducerHealthIndicator(Map<StringDefaultMQProducerproducers
{
      if (producers.size() == 1) {
          return new RocketMQProducerHealthIndicator(producers.values().iterator().next());
      }
  }

7、@Class

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

8、@

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

9、@

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

10、@y

组合 @ 注解,当指定的属性有指定的值时才开启配置。具体操作是通过其两个属性name以及来实现的,其中name用来从.中读取某个属性值,如果该值为空,则返回false;如果值不为空,则将该值与指定的值进行比较,如果一样则返回true;否则返回false。如果返回值为false,则该不生效;为true则生效。

@Bean
 //匹配属性rocketmq.producer.enabled值是否为true
 @ConditionalOnProperty(value = "rocketmq.producer.enabled", havingValue = "true", matchIfMissing = true)
 public RocketMQProducer mqProducer() {
     return new RocketMQProducer();
 }

11、@ion

组合 @ 注解,当 SpEL 表达式为 true 时才开启配置。

@Configuration
@ConditionalOnExpression("${enabled:false}")
public class BigpipeConfiguration {
    @Bean
    public OrderMessageMonitor orderMessageMonitor(ConfigContext configContext) {
        return new OrderMessageMonitor(configContext);
    }
}

12、@

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

13、@e

组合 @ 注解,当类路径下有指定的资源才开启配置。

@Bean
@ConditionalOnResource(resources="classpath:shiro.ini")
protected Realm iniClasspathRealm(){
  return new Realm();
}

14、@

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

15、@

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

16、@

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

17、@ies

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

@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;
}

18、@

当@注解应用到你的@时,任何被@ies注解的beans将自动被属性配置。 这种风格的配置特别适合与的外部YAML配置进行配合使用。

@Configuration
@EnableConfigurationProperties({
    RocketMQProducerProperties.class,
    RocketMQConsumerProperties.class,
})
@AutoConfigureOrder
public class RocketMQAutoConfiguration 
{
    @Value("${spring.application.name}")
    private String applicationName;
}

19、@

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

如 的自动配置类,需要在数据源自动配置类之后。

@AutoConfigureAfter(DataSourceAutoConfiguration.class)
public class MybatisAutoConfiguration 
{
}

20、@

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

21、@

Boot 1.3.0中有一个新的注解@,用于确定配置加载的优先级顺序。

  @AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE) // 自动配置里面的最高优先级
  @Configuration
  @ConditionalOnWebApplication // 仅限于web应用
  @Import(BeanPostProcessorsRegistrar.class) // 导入内置容器的设置
  public class EmbeddedServletContainerAutoConfiguration 
{
      @Configuration
      @ConditionalOnClass({ Servlet.classTomcat.class })
      @ConditionalOnMissingBean(value 
= EmbeddedServletContainerFactory.classsearch = SearchStrategy.CURRENT)
      public static class EmbeddedTomcat {
         // ...
      }

      @Configuration
      @ConditionalOnClass({ Servlet.classServer.classLoader.classWebAppContext.class })
      @ConditionalOnMissingBean(value 
= EmbeddedServletContainerFactory.classsearch = SearchStrategy.CURRENT)
      public static class EmbeddedJetty {
         // ...
      }
}

感谢阅读,希望对你有所帮助:)

来源:///

/

精彩推荐

最全的java面试题库

开源版的高仿 “ 微信 ”,吊炸天!

后端技术内卷群,一起学习!

图片


限时特惠:
本站持续每日更新海量各大内部创业课程,一年会员仅需要98元,全站资源免费下载
点击查看详情

站长微信:Jiucxh

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注