两个常见的 AutoConfiguration 类源码分析

1.DataSourceAutoConfiguration 源码分析

@Configuration
@ConditionalOnClass({ DataSource.class, EmbeddedDatabaseType.class })
@EnableConfigurationProperties(DataSourceProperties.class)
public class DataSourceAutoConfiguration {

    // 内部类定义了数据源相关的条件
    @ConditionalOnMissingBean(DataSource.class)
    static class DefaultDataSourceConfiguration {

        // 创建数据源的逻辑
        @Bean
        public DataSource dataSource(DataSourceProperties properties) {
            // 具体的创建数据源代码
        }
    }
}

在DataSooureAutoConfiguration中,通过注解@ConditionClass确保存在DataSource和Embeddeddatabasetype类。@EnabkeConfigurationProperties启用了DataSouceProperties和配置属性绑定。内部的静态类在没有已存在的数据源Bean时创建默认的数据源。

2.WebMvcAutoConfiguration 源码分析

@Configration
@ConditionOnWebApplication(Type = Type.SERVLET)
@ConditonalOnClass({Servlet.class,DisPatcherServlet.class,WebMvcConfigurer.class})
@AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE)
@AutoCongiguerAfter({ DispatcherServletAutoConfiguration.class,TaskExecutionAutoConfiguration.class })
public class WebMvcAutoConfiguration{
       //定义了各种配置和组件的创建逻辑
        @Bean
        public ViewResolve viewResolve(ContentnegotiationManager manager){
        //创建视图解析器代码
        }
}

在WebMvcAutoConfiguration中通过一系列条件注解来控制其生效条件。定义了如视图解析器等各中Web MVC 相关的组件和配置。

3.总结配置原理

        Spring Boot 的自动配置原理是通过一系列的条件判断、依赖管理、配置类定义和资源加载机制,来实现根据项目的实际情况自动完成相关组件和配置的加载,从而大大简化了开发过程。

1.条件注解(Coditonal Annotations):通过诸如@ConditionalOnClass、@ConditionalOnProperty等条件注解,来判断当前环境是否满足自动配置条件。只有当条件满足时,相关的配置类或组件才会生效。

2.起步依赖(Starter Dependencies):在项目依赖管理中引入特定的起步依赖,这些依赖会传递引入一系列相关依赖,同时出发对应的自动配置。

3.配置类(Configuration Classes):定义了各种自动配置的类,这些类中包含了创建Bean、设置属性、注入依赖等逻辑。

4.资源加载(Resouce Loading):从类路径下的META-INF/spring.factories文件中加载自动配置类的信息。

5.优先级和排序(Priority and Ordering):自动配置类之间可能存在优先级和执行顺序的关系,以确保配置的正确性和合理性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值