这篇博文我们重点介绍是如何实现的自动配置

依赖管理

在我们的pom文件中最核心的依赖就一个:


    org.springframework.boot
    spring-boot-starter-parent
    2.4.4
    

它的父项目依赖,规定所有依赖的版本信息:


  org.springframework.boot
  spring-boot-dependencies
  2.4.4

由此,我们发现框架几乎声明了所有开发中常用的依赖的版本号,无需关注版本号,而且实现了自动版本仲裁机制,当然了我们也可以根据我们的需要,替换掉默认的依赖版本。

核心注解@n

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

在上面的启动类中我们发现了一个陌生的注解@n,这个注解的是什么含义呢?我们点进去看一下。

@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(excludeFilters = { @Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
      @Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })

其实@n是上面三个注解的组合体,我们对这三个注解理解清楚就可以了,下面逐个进行解释:

@ion

@Configuration
public @interface SpringBootConfiguration {

@我们并不陌生,它允许在上下文中注册额外的bean或导入其他配置类,@ion其实代表当前类是一个配置类。

@ion

ion的目的是启动的自动配置机制。

@AutoConfigurationPackage
@Import(AutoConfigurationImportSelector.class)
public @interface EnableAutoConfiguration {

1、kage指定默认的包规则

@Import(AutoConfigurationPackages.Registrar.class)
public @interface AutoConfigurationPackage {

kage注解的作用是将 添加该注解的类所在的 作为 自动配置 进行管理。也就是说当应用启动时默认会将启动类所在的作为自动配置的。然后使用@注解将其注入到ioc容器中。这样,可以在容器中拿到该路径。

static class Registrar implements ImportBeanDefinitionRegistrar, DeterminableImports {
   @Override
   public void registerBeanDefinitions(AnnotationMetadata metadata, BeanDefinitionRegistry registry) {
      register(registry, new PackageImports(metadata).getPackageNames().toArray(new String[0]));
   }
   @Override
   public Set determineImports(AnnotationMetadata metadata) {
      return Collections.singleton(new PackageImports(metadata));
   }
}

重点看下ons方法。

方法的第二个参数通过new ().()方法设置。

接着看下的构造器方法。

PackageImports(AnnotationMetadata metadata) {
   AnnotationAttributes attributes = AnnotationAttributes
         .fromMap(metadata.getAnnotationAttributes(AutoConfigurationPackage.class.getName(), false));
   List packageNames = new ArrayList(Arrays.asList(attributes.getStringArray("basePackages")));
   for (Class basePackageClass : attributes.getClassArray("basePackageClasses")) {
      packageNames.add(basePackageClass.getPackage().getName());
   }
   if (packageNames.isEmpty()) {
      packageNames.add(ClassUtils.getPackageName(metadata.getClassName()));
   }
   this.packageNames = Collections.unmodifiableList(packageNames);
}

.(.())获取标注@kage注解的类的全限定名。

最后,利用给容器中导入一系列组件,将指定的包下的所有组件导入进来。

2、@(.class)

使用自动导入所有符合自动配置条件的Bean定义并加载到IOC容器

@Override
		public void process(AnnotationMetadata annotationMetadata, DeferredImportSelector deferredImportSelector) {
			Assert.state(deferredImportSelector instanceof AutoConfigurationImportSelector,
					() -> String.format("Only %s implementations are supported, got %s",
							AutoConfigurationImportSelector.class.getSimpleName(),
							deferredImportSelector.getClass().getName()));
			AutoConfigurationEntry autoConfigurationEntry = ((AutoConfigurationImportSelector) deferredImportSelector)
					.getAutoConfigurationEntry(annotationMetadata);
			this.autoConfigurationEntries.add(autoConfigurationEntry);
			for (String importClassName : autoConfigurationEntry.getConfigurations()) {
				this.entries.putIfAbsent(importClassName, annotationMetadata);
			}
		}

1、利用Entry();给容器中批量导入一些组件

2、调用List = (, )获取到所有需要导入到容器中的配置类

3、利用工厂加载 Map (@ );得到所有的组件

4、从META-INF/.位置来加载一个文件。

默认扫描我们当前系统里面所有META-INF/.位置的文件

-boot–2.4.4..jar包里面也有META-INF/.

springboot自动装配原理_自动装配spring_springboot自动装配原理

文件里面写死了-boot一启动就要给容器中加载的所有配置类-boot–2.4.4..jar/META-INF/.,一共130个自动配置类。

130个场景的所有自动配置,会在启动的时候默认全部加载。n会按照条件装配规则(@),最终会按需配置。

小结:

为我们的应用程序启用了三个功能:自动配置,组件扫描,以及能够在”应用类”上定义额外的配置。

@

@在应用程序所在的软件包上启用扫描,指定扫描哪些注解。

为例

在130个场景有我们比较熟悉两个组件,和ion,我们以为例,看一下是如何自动装配的。

自动装配spring_springboot自动装配原理_springboot自动装配原理

在注解中我们看到了大量以@开头的注解,即条件装配,满足指定的条件,则进行组件注入。@(.class)+@ies( = “”, = true),读取我们在配置文件编写的属性,并把它封装到中,以供随时使用。

此时我们的容器已经以Bean的形式被注入到了IOC容器中。

如何禁用特定的自动配置类

如果发现应用中不需要特定自动配置类,则可以使用属性@n来禁用它们,如以下示例所示:

import org.springframework.boot.autoconfigure.*;
import org.springframework.boot.autoconfigure.jdbc.*;
@SpringBootApplication(exclude={DataSourceAutoConfiguration.class})
//@SpringBootApplication(excludeName = {"org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration"})
public class MyApplication {
}

如果该类不在类路径中,则可以使用注释的属性,并指定完全限定的名称(全类名字符串)。定义排除项,即可以使用哪个注释级别也可以使用属性来定义。

总结

预先加载META-INF/.中所有的自动配置类,on

每个自动配置类按照条件进行生效,默认都会绑定配置文件指定的值。里面拿。和配置文件进行了绑定

生效的配置类就会给容器中装配很多组件,只要容器中有这些组件,相当于有了这些功能

定制化配置

用户直接自己@Bean替换底层的组件

用户根据这个组件是获取的配置文件的什么值,可以自行修改。

ion —> 扫描on —> 根据条件@装配组件 —>根据加载属性值 —-> .

———END———
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,永久会员只需109元,全站资源免费下载 点击查看详情
站 长 微 信: nanadh666

声明:1、本内容转载于网络,版权归原作者所有!2、本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。3、本内容若侵犯到你的版权利益,请联系我们,会尽快给予删除处理!
  1. 免费下载或者VIP会员资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
  2. 提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或联络我们。
  3. 找不到素材资源介绍文章里的示例图片?
    对于会员专享、整站源码、程序插件、网站模板、网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
  4. 付款后无法显示下载地址或者无法查看内容?
    如果您已经成功付款但是网站没有弹出成功提示,请联系站长提供付款信息为您处理
  5. 购买该资源后,可以退款吗?
    源码素材属于虚拟商品,具有可复制性,可传播性,一旦授予,不接受任何形式的退款、换货要求。请您在购买获取之前确认好 是您所需要的资源