@Enable*注解怎么在springBoot中使用

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)@Enable* 注解怎么在springBoot中使用,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

浮梁網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),浮梁網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為浮梁1000多家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請找那個售后服務(wù)好的浮梁做網(wǎng)站的公司定做!

1、為什么使用@SpringBootApplication注解,即可做到自動配置?

答:@SpringBootApplication,內(nèi)部起作用的注解其實有3個。@EnableAutoConfiguration,@ComponentScan,@Configuration。這篇文章主要是講解@EnableXX注解

2、為什么使用了@EnableAutoConfiguration。當(dāng)使用了@ConfigurationProperties時,即可自動導(dǎo)入.yml 或者.properties里面的配置項?

答:在@EnableAutoConfiguration內(nèi)部,使用了@Import注解。導(dǎo)入AutoConfigurationImportSelector幫助springBoot將符合條件的Configuration加載到IOC容器中。但是內(nèi)部其實使用了SpringFactoriesLoader來完成。類似與java SPI的功能
,即從/META-INF/spring.factories加載配置

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
@Import({AutoConfigurationImportSelector.class})
public @interface EnableAutoConfiguration

可以看到@Import中,其實是導(dǎo)入了一個AutoConfigurationImportSelector的類。最關(guān)鍵的是,該類實現(xiàn)了接口ImportSelector

public interface ImportSelector {
 /**
  * Select and return the names of which class(es) should be imported based on
  * the {@link AnnotationMetadata} of the importing @{@link Configuration} class.
  */
 String[] selectImports(AnnotationMetadata importingClassMetadata);

}

這是ImportSelector的描述,大概意思就是,該方法返回的Bean 會自動的被注入,被Spring所管理。

接著來看 AutoConfigurationImportSelector中 selectImports 的實現(xiàn)

public String[] selectImports(AnnotationMetadata annotationMetadata) {
  if(!this.isEnabled(annotationMetadata)) {
   return NO_IMPORTS;
  } else {
   AutoConfigurationMetadata autoConfigurationMetadata = AutoConfigurationMetadataLoader.loadMetadata(this.beanClassLoader);
   AnnotationAttributes attributes = this.getAttributes(annotationMetadata);
   List<String> configurations = this.getCandidateConfigurations(annotationMetadata, attributes);
   configurations = this.removeDuplicates(configurations);
   Set<String> exclusions = this.getExclusions(annotationMetadata, attributes);
   this.checkExcludedClasses(configurations, exclusions);
   configurations.removeAll(exclusions);
   configurations = this.filter(configurations, autoConfigurationMetadata);
   this.fireAutoConfigurationImportEvents(configurations, exclusions);
   return StringUtils.toStringArray(configurations);
  }
 }

代碼都寫得很清楚。就不解釋了。

在@Import中,可以看到 有個鏈接指向了 ImportBeanDefinitionRegistrar。這同樣是一個接口,作用跟 ImportSelector 一樣。

public interface ImportBeanDefinitionRegistrar {
 public void registerBeanDefinitions(
   AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry);

}

在registerBeanDefinitions方法中,可以用BeanDefinitionRegistry 注入我們想要注入的Bean。

代碼示例:

使用@Import編寫自己的@Enable

1、創(chuàng)建2個測試Bean

public class Role {
}

public class User {
}

2、自定義Enable注解

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Import(MyEnableAutoConfig.class)
public @interface EnableBean {
}

3、實現(xiàn)自己的EnableAutoConfiguration類

public class MyEnableAutoConfig implements ImportSelector{
 @Override
 public String[] selectImports(AnnotationMetadata importingClassMetadata) {
  return new String[]{"com.xhn2.Role","com.xhn2.User"};
 }
}

4、編寫啟動類

@EnableBean
@ComponentScan("com.xhn2")
public class Main {
 public static void main(String[] args) {
  ConfigurableApplicationContext context = SpringApplication.run(Main.class, args);
  System.out.println(context.getBean(User.class));
  System.out.println(context.getBean(Role.class));
 }
}

5、運行結(jié)果

com.xhn2.User@496bc455
com.xhn2.Role@59402b8f

控制臺成功打印。

代碼示例2,自動裝配第3方j(luò)ar包的Bean

新建maven工程

1、pom.xml

<modelVersion>4.0.0</modelVersion>

 <groupId>org.csp</groupId>
 <artifactId>hello</artifactId>
 <version>1.0.0</version>

 <properties>
  <maven.compiler.source>1.8</maven.compiler.source>
  <maven.compiler.target>1.8</maven.compiler.target>
  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 </properties>

 <dependencies>
  <dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-context</artifactId>
  <version>4.3.17.RELEASE</version>
  </dependency>
 </dependencies>

2、編寫Configuration

@Configuration
public class MyTest {
 @Bean
 public Runnable runnable() {
  return ()->{};
 }
}

在resources下新建META-INF/spring.factories文件,加入以下配置

org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.edu.MyTest

3、將項目安裝到本地maven倉庫:mvn install

4、主工程引入剛才安裝到本地的jar。

<dependency>
   <groupId>org.csp</groupId>
   <artifactId>hello</artifactId>
   <version>1.0.0</version>
  </dependency>

5、獲取剛才配置的Runnable

@SpringBootApplication
public class Main {
 public static void main(String[] args) {
  SpringApplication application = new SpringApplication(Main.class);
  ConfigurableApplicationContext context = application.run(args);
  System.out.println(context.getBean(Runnable.class));
 }
}

6、控制臺打印

com.edu.MyTest$$Lambda$153/284686302@2c07545f

上述就是小編為大家分享的@Enable* 注解怎么在springBoot中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前標(biāo)題:@Enable*注解怎么在springBoot中使用
分享URL:http://muchs.cn/article4/jopjie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、響應(yīng)式網(wǎng)站小程序開發(fā)、App設(shè)計、服務(wù)器托管網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)