<context:component-scan>扫描@Component @Controller@Service注解的的类 <mvc:annotation-driven />启用注解
2016-12-14 11:01
453 查看
1.在xml配置了这个标签后,spring可以自动去扫描base-pack下面或者子包下面的Java文件,如果扫描到有@Component
@Controller@Service等这些注解的类,则把这些类注册为bean
2.在此之间一定要加上:<mvc:annotation-driven />启用注解(启用@Component
@Controller@Service等)
3.在xml中配置了这两项就可以实现:前端页面通过路径找到控制器里的方法了
例如:
<a href=“路径地址
">页</a>
<form action=" 路径地址"
method="post">
<img id="imgObj" src=" 路径地址"/>
bde9
注意:如果配置了<context:component-scan>那么<context:annotation-config/>标签就可以不用再xml中配置了,因为前者包含了后者。另外<context:annotation-config/>还提供了两个子标签
1. <context:include-filter>
2. <context:exclude-filter>
在说明这两个子标签前,先说一下<context:component-scan>有一个use-default-filters属性,改属性默认为true,这就意味着会扫描指定包下的全部的标有@Component的类,并注册成bean.也就是@Component的子注解@Service,@Reposity等。所以如果仅仅是在配置文件中这么写
<context:component-scan base-package="tv.huan.weisp.web"/>
Use-default-filter此时为true那么会对base-package包或者子包下的所有的进行java类进行扫描,并把匹配的java类注册成bean。
可以发现这种扫描的粒度有点太大,如果你只想扫描指定包下面的Controller,该怎么办?此时子标签<context:incluce-filter>就起到了勇武之地。如下所示
<context:component-scan base-package="tv.huan.weisp.web .controller">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</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>指定的扫描
@Controller@Service等这些注解的类,则把这些类注册为bean
2.在此之间一定要加上:<mvc:annotation-driven />启用注解(启用@Component
@Controller@Service等)
3.在xml中配置了这两项就可以实现:前端页面通过路径找到控制器里的方法了
例如:
<a href=“路径地址
">页</a>
<form action=" 路径地址"
method="post">
<img id="imgObj" src=" 路径地址"/>
bde9
注意:如果配置了<context:component-scan>那么<context:annotation-config/>标签就可以不用再xml中配置了,因为前者包含了后者。另外<context:annotation-config/>还提供了两个子标签
1. <context:include-filter>
2. <context:exclude-filter>
在说明这两个子标签前,先说一下<context:component-scan>有一个use-default-filters属性,改属性默认为true,这就意味着会扫描指定包下的全部的标有@Component的类,并注册成bean.也就是@Component的子注解@Service,@Reposity等。所以如果仅仅是在配置文件中这么写
<context:component-scan base-package="tv.huan.weisp.web"/>
Use-default-filter此时为true那么会对base-package包或者子包下的所有的进行java类进行扫描,并把匹配的java类注册成bean。
可以发现这种扫描的粒度有点太大,如果你只想扫描指定包下面的Controller,该怎么办?此时子标签<context:incluce-filter>就起到了勇武之地。如下所示
<context:component-scan base-package="tv.huan.weisp.web .controller">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</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>指定的扫描
相关文章推荐
- <context:annotation-config/>,<mvc:annotation-driven/>和<context:component-scan>之间的关系
- <mvc:annotation-driven >和<context:component-scan>
- <context:annotation-config/>,<mvc:annotation-driven/>和<context:component-scan>之间的关
- <mvc:annotation-driven/> <context:annotation-config/> <context:component-scan>
- <context:annotation-config/> (只用注解)---<context:component-scan/>(扫描自带注解)
- <context:annotation-config/>,<context:component-scan/>,<mvc:annotation-driven/>区分
- SpringMVC - <context:annotation-config/>与<mvc:annotation-driven/>和<context:component-scan>
- <mvc:annotation-driven/>、<context:component-scan base-package=""/>、<context:annotation-config/>的用法
- Spring <context:annotation-config/> <context:component-scan/>与<mvc:annotation-driven />
- <context:annotation-config/>,<mvc:annotation-driven/>和<context:component-scan>之间的关系
- <mvc:annotation-driven/>,<context:annotation-config/>,<context:component-scan/>详解
- spring mvc <mvc:annotation-driven/> 和<context:component-scan base-package=""/>解释
- Spring <context:component-scan/>与<mvc:annotation-driven/>
- <context:component-scan/> <mvc:annotation-driven /> 区别
- Spring注解之xml配置中的<context:component-scan />和<context:annotation-config/>
- 关于spring注解启用的两种方式<context:component-scan>和<context:annotation-config/>
- Spring mvc——接收对象Json数据,<mvc:annotation-driven/><context:annotation-config/><context:component-scan/>
- <context:component-scan/>和<mvc:annotation-driven/>区别
- Spring配置 <context:component-scan/> <mvc:annotation-driven />
- <mvc:annotation-driven/>、<context:component-scan base-package=""/>、<context:annotation-config/>的用法