Spring 学习二 @ComponentScan 组件扫描

本文深入探讨了Spring框架中@ComponentScan注解的使用方法,包括如何通过该注解指定扫描的包路径,如何使用includeFilters和excludeFilters来精确控制哪些组件被扫描或排除。文章详细解析了Filter和ComponentScan注解的参数,如type和classes,以及useDefaultFilters的默认行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

IOC 容器默认扫描 @Controller,@Service,@Repository,@Component 注解的组件

  • @ComponentScan 部分源码

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
@Documented
@Repeatable(ComponentScans.class)
public @interface ComponentScan {
	/**  是否使用默认规则  */
	boolean useDefaultFilters() default true;

	/**  包含扫描的组件 */
	Filter[] includeFilters() default {};

	/** 不扫描的组件 */
	Filter[] excludeFilters() default {};
}
  • @Filter 部分源码

@Retention(RetentionPolicy.RUNTIME)
@Target({})
@interface Filter {
	/** 过滤规则,按什么类型过滤 */
	FilterType type() default FilterType.ANNOTATION;

	/** 需要过滤的组件 */
	@AliasFor("classes")
	Class<?>[] value() default {};
}
  • 排除组件,不扫描组件

@Configuration
@ComponentScan(value = "com.john", excludeFilters = { @Filter(type = FilterType.ANNOTATION, classes = { Controller.class }) })
public class BeanConfig {
// 说明:排除带 @Controller 注解的组件,不扫描
}
  • 包含组件,扫描组件

@Configuration
@ComponentScan(value = "com.john", includeFilters = { @Filter(type = FilterType.ANNOTATION, classes = { Controller.class }) }, useDefaultFilters = false)
public class BeanConfig {
// 说明:只扫描com.john 包下面的 带@Controller 注解的组件,使用 includeFilters,需要禁用默认规则,即设置 useDefaultFilters = false
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值