SpringBoot 2.x 核心注解分析

简介: @SpringBootApplication是SpringBoot最核心的注解,一般标注在启动类的上面。它是一个复合注解,包含了@ComponentScan、@SpringBootConfiguration、@EnableAutoConfiguration,下面逐一分析这三个注解。

一、@SpringBootApplication

@SpringBootApplication是SpringBoot最核心的注解,一般标注在启动类的上面,它包含了@ComponentScan@SpringBootConfiguration@EnableAutoConfiguration,下面逐一分析这三个注解。

@SpringBootApplication
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(JkExperimentApplication.class, args);
    }
}

二、@ComponentScan、@Component

1. IoC容器扫描Bean

@Component是标明哪个类被扫描进入Spring IoC容器。
@ComponentScan则是标明采用何种策略去扫描标记了@Component的类型,注意:只会扫描当前包和其子包。
举个栗子:采用自定义策略进行扫描。

//自定义排查的扫描类
@ComponentScan(
    excludeFilters = {
      @Filter(type = FilterType.CUSTOM,classes = {TypeExcludeFilter.class}), 
      @Filter(type = FilterType.CUSTOM,classes = {AutoConfigurationExcludeFilter.class})
    }
)
public @interface SpringBootApplication {
}


@Component
public class Cat implements Animal {
  ...
}

@Component
public class Dog implements Animal {
  ...
}

2.从IoC容器中读取Bean(依赖注入)

通过@Autowired依赖注入从而获取容器中的实例。
Spring IoC容器是通过getBean方法获取对应Bean的,而getBean又支持根据类型(by type)或者根据名称(byname)。首先@Autowired会根据类型找到对应的Bean,如果对应类型的Bean不是唯一的,那么它会根据其属性名称和Bean的名称进行匹配。如果匹配得上,就会使用该Bean;如果还无法匹配,就会抛出异常。
执行下面代码,IoC容器会抛出异常,因为Animal有Cat和Dog两种Bean。

@Autowired
private Animal animal=null;

解决方案1:

@Autowired
private Animal dog=null;

解决方案2:
@Primary,它是一个修改优先权的注解。

@Component
@Primary
public class Dog implements Animal {
  ...
}

注意:有时候@Primary也可以使用在多个类上,也许无论是猫还是狗都可能带上@Primary注解,其结果是IoC容器还是无法区分采用哪个Bean的实例进行注入。

解决方案3:
@Quelifier,与@Autowired组合在一起使用。通过指定名称,再和类型一起找到Bean。

//在属性中使用
@Autowired
@Quelifier("dog")
private Animal animal=null;

//在构造方法中使用
@Component
public class Man implements Person {
    private Animal animal=null;
    public Man(@Autowired @Quelifier("dog") Animal animal){
        this.animal=animal;
    }
}

三、@SpringBootConfiguration

@SpringBootConfiguration是一个复合注解,引入了@Configuration@Configuration用于定义配置类,可以通过注解@Value去获取application.properties里面的配置项。
被注解的类内部也可以包含有一个或多个被@Bean注解的方法,这些方法将会被AnnotationConfigApplicationAnnotationConfigWebApplication类进行扫描,并用于构建bean定义,初始化Spring IoC容器。

//MyConfiguration 
@Configuration
public class MyConfiguration {

    public MyConfiguration(){
        System.out.println("容器初始化中....");
    }
    
    @Value("${user.name}")
    private String userName;

    @Bean
    public User getUser(){
        User user = new User();
        user.setName(this.userName);
        user.setPwd("123456");
        return user;
    }      
}
public static void main(String[] args) {
    ApplicationContext applicationContext = new AnnotationConfigApplicationContext(MyConfiguration.class);
    //从ioc 容器中获取bean
    User user = (User) applicationContext.getBean("getUser");
    System.out.println( user.toString());
}

四、@EnableAutoConfiguration
@ComponentScan只能扫描当前包和子包,只能加载当前包和子包的@Configuration@Configuration引入了@Component)。 而@EnableAutoConfiguration可以帮助SpringBoot应用将所有符合条件的包括依赖的jar包的@Configuration配置都加载到当前SpringBoot创建并使用的IoC容器。
@EnableAutoConfiguration源码:

package org.springframework.boot.autoconfigure;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.context.annotation.Import;

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

    Class<?>[] exclude() default {};

    String[] excludeName() default {};
}

其中最关键的要属@Import(AutoConfigurationImportSelector.class),在AutoConfigurationImportSelector类中可以看到通过 SpringFactoriesLoader.loadFactoryNames()
spring-boot-autoconfigure.jar和其他依赖jar包的/META-INF/spring.factorie文件中标注的类都加载到容器中,(spring.factores:用来指导SpringBoot找到指定的配置文件。),
然后将其中对应的配置项通过反射实例化为对应标注了@Configration的IoC容器配置类,最后汇总并加载到Spring框架的IoC容器中。

在这里插入图片描述
在这里插入图片描述

目录
相关文章
|
3月前
|
安全 NoSQL Java
SpringBoot接口安全:限流、重放攻击、签名机制分析
本文介绍如何在Spring Boot中实现API安全机制,涵盖签名验证、防重放攻击和限流三大核心。通过自定义注解与拦截器,结合Redis,构建轻量级、可扩展的安全防护方案,适用于B2B接口与系统集成。
617 3
|
3月前
|
缓存 监控 Java
SpringBoot @Scheduled 注解详解
使用`@Scheduled`注解实现方法周期性执行,支持固定间隔、延迟或Cron表达式触发,基于Spring Task,适用于日志清理、数据同步等定时任务场景。需启用`@EnableScheduling`,注意线程阻塞与分布式重复问题,推荐结合`@Async`异步处理,提升任务调度效率。
609 128
|
3月前
|
XML 安全 Java
使用 Spring 的 @Aspect 和 @Pointcut 注解简化面向方面的编程 (AOP)
面向方面编程(AOP)通过分离横切关注点,如日志、安全和事务,提升代码模块化与可维护性。Spring 提供了对 AOP 的强大支持,核心注解 `@Aspect` 和 `@Pointcut` 使得定义切面与切入点变得简洁直观。`@Aspect` 标记切面类,集中处理通用逻辑;`@Pointcut` 则通过表达式定义通知的应用位置,提高代码可读性与复用性。二者结合,使开发者能清晰划分业务逻辑与辅助功能,简化维护并提升系统灵活性。Spring AOP 借助代理机制实现运行时织入,与 Spring 容器无缝集成,支持依赖注入与声明式配置,是构建清晰、高内聚应用的理想选择。
467 0
|
3月前
|
Java 测试技术 API
将 Spring 的 @Embedded 和 @Embeddable 注解与 JPA 结合使用的指南
Spring的@Embedded和@Embeddable注解简化了JPA中复杂对象的管理,允许将对象直接嵌入实体,减少冗余表与连接操作,提升数据库设计效率。本文详解其用法、优势及适用场景。
312 126
|
2月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
443 2
|
3月前
|
Java 测试技术 数据库
使用Spring的@Retryable注解进行自动重试
在现代软件开发中,容错性和弹性至关重要。Spring框架提供的`@Retryable`注解为处理瞬时故障提供了一种声明式、可配置的重试机制,使开发者能够以简洁的方式增强应用的自我恢复能力。本文深入解析了`@Retryable`的使用方法及其参数配置,并结合`@Recover`实现失败回退策略,帮助构建更健壮、可靠的应用程序。
458 1
使用Spring的@Retryable注解进行自动重试
|
3月前
|
XML Java 数据格式
常用SpringBoot注解汇总与用法说明
这些注解的使用和组合是Spring Boot快速开发和微服务实现的基础,通过它们,可以有效地指导Spring容器进行类发现、自动装配、配置、代理和管理等核心功能。开发者应当根据项目实际需求,运用这些注解来优化代码结构和服务逻辑。
329 12
|
3月前
|
传感器 Java 数据库
探索Spring Boot的@Conditional注解的上下文配置
Spring Boot 的 `@Conditional` 注解可根据不同条件动态控制 Bean 的加载,提升应用的灵活性与可配置性。本文深入解析其用法与优势,并结合实例展示如何通过自定义条件类实现环境适配的智能配置。
204 0
探索Spring Boot的@Conditional注解的上下文配置
|
3月前
|
智能设计 Java 测试技术
Spring中最大化@Lazy注解,实现资源高效利用
本文深入探讨了 Spring 框架中的 `@Lazy` 注解,介绍了其在资源管理和性能优化中的作用。通过延迟初始化 Bean,`@Lazy` 可显著提升应用启动速度,合理利用系统资源,并增强对 Bean 生命周期的控制。文章还分析了 `@Lazy` 的工作机制、使用场景、最佳实践以及常见陷阱与解决方案,帮助开发者更高效地构建可扩展、高性能的 Spring 应用程序。
157 0
Spring中最大化@Lazy注解,实现资源高效利用