@ComponentScans注解
1.只有一个属性 value
2.value值是一个ComponentScan的数组
3.点进去看到@ComponentScan,@Repeatable 注解表明是可以重复声明的
4.在@ComponentScan里面需要声明
(1)value值,表示的是需要扫描的基本包(basePackages);
(2)useDefaultFilters,表示默认过滤:只要有 @Component,@Repository, { @Service}, or { @Controller}注解的组件全部导入容器中;
(3)includeFilters:里面是@Filters的数组,可以声明多个过滤器;必须和 useDefaultFilters = false
(4)@Filter 里面有过滤类型
FilterType.ANNOTATION:按照注解
FilterType.ASSIGNABLE_TYPE:按照给定的类型;
FilterType.REGEX:使用正则指定
FilterType.CUSTOM:使用自定义规则-----需要实现TypeFilter接口
(5)excludeFilters 正常使用,不需要搭配useDefaultFilters
@ComponentScan加上之后 @Controller 和其他注解声明的组件才有效,才会被放在容器里面
5. FilterType.CUSTOM 自定义拦截规则
1.使用自定义拦截器,就必须自己写一个实现了TypeFilter的实现类
2.自定义 MyTypeFilter 类实现 implements TypeFilter接口方法
3.实现接口
4. 实现接口之后,将经过这个拦截器的class文件全部打印出来
原理:根据@Component 扫描com.atguigu 包下面的所有文件,该文件下有这么多class文件,所以这些文件类名全部打印出来了