使用说明

在xml配置了这个标签后,spring能够自动去扫描base-pack下面或者子包下面的java文件,若是扫描到有@Component @Controller @Service等这些注解的类,则把这些类注册为bean java

注意:若是配置了<context:component-scan>那么<context:annotation-config/>标签就能够不用再xml中配置了,由于前者包含了后者。另外<context:annotation-config/>还提供了两个子标签 web

1.        <context:include-filter> spring

2.       <context:exclude-filter> express

在说明这两个子标签前,先说一下<context:component-scan>有一个use-default-filters属性,改属性默认为true,这就意味着会扫描指定包下的所有的标有@Component的类,并注册成bean.也就是@Component的子注解@Service,@Reposity。因此若是仅仅是在配置文件中这么写 spa

<context:component-scan base-package="tv.huan.weisp.web"/> .net

 Use-default-filter此时为true那么会对base-package包或者子包下的全部的进行java类进行扫描,并把匹配的java类注册成bean。 component

 

 能够发现这种扫描的粒度有点太大,若是你只想扫描指定包下面的Controller,该怎么办?此时子标签<context:incluce-filter>就起到了勇武之地。以下所示 xml

<context:component-scan base-package="tv.huan.weisp.web .controller">   get

<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>    it

</context:component-scan>  

这样就会只扫描base-package指定下的有@Controller下的java类,并注册成bean

可是由于use-dafault-filter在上面并无指定,默认就为true,因此当把上面的配置改为以下所示的时候,就会产生与你指望相悖的结果(注意base-package包值得变化)

<context:component-scan base-package="tv.huan.weisp.web ">  

<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>   

</context:component-scan>  

此时,spring不只扫描了@Controller,还扫描了指定包所在的子包service包下注解@Service的java类

此时指定的include-filter没有起到做用,只要把use-default-filter设置成false就能够了。这样就能够避免在base-packeage配置多个包名这种不是很优雅的方法来解决这个问题了。

另外在我参与的项目中能够发如今base-package指定的包中有的子包是不含有注解了,因此不用扫描,此时能够指定<context:exclude-filter>来进行过滤,说明此包不须要被扫描。综合以上说明

Use-dafault-filters=”false”的状况下:<context:exclude-filter>指定的不扫描,<context:include-filter>指定的扫描