文章目录
前言
@Enable*注解
Springboot中提供了很多Enable开头的注解,这些注解用于动态的开启某些功能。而底层原理是使用了@Import注解导入了一些配置类,实现Bean的动态加载。
第一节、问题:引入一个jar能直接获取它的Bean吗
新建两个工程,用例子来说明
pojo工程
- 创建一个springboot模块(不选择任何组件)
- 编写User
package com.it2.pojo.springbootenablepojo.pojo;
public class User {
}
- 编写UserConfig
package com.it2.pojo.springbootenablepojo.config;
import com.it2.pojo.springbootenablepojo.pojo.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class UserConfig {
@Bean
public User user(){
return new User();
}
}
- 安装这个依赖到本地仓库 mvn install
enable工程(引入pojo)
- 新建enable工程
- 导入pojo依赖
<dependency>
<groupId>com.it2.pojo</groupId>
<artifactId>springboot-enable-pojo</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
- 获取user
package com.it2.springbootenable.springbootenable01;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
@SpringBootApplication
public class SpringbootEnable01Application {
public static void main(String[] args) {
ConfigurableApplicationContext context=SpringApplication.run(SpringbootEnable01Application.class, args);
Object obj=context.getBean("user");
System.out.println(obj);
}
}
- 运行项目。发现虽然引入了依赖,但是并没有创建user这个bean
j结论:
通过例子说明,直接引入依赖,容器是不会初始化导入的Bean。
第二节、如何获取到user这个Bean
第一种、配置@ComponentScan
我们发现UserConfig和启动类并不是同一个包,UserConfig也不是启动类的子包。只有启动类同级或者子包才能被扫描到IOC容器中,所以我们需要手动配置包扫描,去扫描UserConfig,
给启动类添加注解
@ComponentScan("com.it2.pojo.springbootenablepojo.config")
再次运行,发现从IOC容器能获取到User
导入一个包,就要去配置包扫描,很繁琐。
第二种、配置@Import注解
通过@Import注解,导入UserConfig
@Import(UserConfig.class)
再次运行,同样可以获取到User。
通过@Import注解,我们需要事先知道UserConfig,这显的并不方便,如果有很多Config,意味着不仅要提前知道Config名称,还要配置一堆。
第三种、配置@Enable注解
在pojo模块种自定义一个EnableUser的注解
package com.it2.pojo.springbootenablepojo.config;
import org.springframework.context.annotation.Import;
import java.lang.annotation.*;
/**
* 其实Enable注解就是将Import注解进行封装
*/
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Import(UserConfig.class)
public @interface EnableUser {
}
在启动类添加@EnableUser注解
再次运行,同样可以获取到User
明显在使用@EnableUser时,只要添加注解即可,不需要进行复杂的配置,也不需要提前知道UserConfig。