use-default-filters 这个属性的作用:
use-default-filters 属性的默认值为 true,即使用默认的 Filter 进行包扫描,而默认的 Filter 对标有 @Service,@Controller和@Repository 的注解的类进行扫描,因为前面说过,我们希望 SpringMVC 只来控制网站的跳转逻辑,所以我们只希望 SpringMVC 的配置扫描 @Controllerce 注解标注的类,不希望它扫描其余注解标注的类,所以设置了 use-default-filters 为 false,并使用 context:include-filter 子标签设置其只扫描带有 @Controller 注解标注的类。
SpringMVC :
主要就是来管理网站的跳转逻辑,所以在配置扫描的包时,只希望 SpringMVC 的配置扫描 @Controllerce 注解标注的类,不希望它扫描其余注解标注的类,使用 use-default-filters 属性,并设置为 false,即不使用默认的 Filter 进行扫描。并使用 context:include-filter 子标签设置其只扫描带有 @Controller 注解标注的类。
例如:
<context:component-scan base-package="com.j" use-default-filters="false"> <!--只扫描Controller层--> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan> -->
applicationContext:
Spring 的配置,希望 Spring 只不扫描带有 @Controller 注解标注的类,而扫描其他注解标注的类,而这时建立在使用默认的 Filter 进行扫描的基础上,设置了 context:exclude-filter 标签,不扫描 @Controller 注解标注的类,所以不应该设置 use-default-filters 为 false。
例如:
<context:component-scan base-package="com.j"> <!-- 除了控制器controller外,全部扫描 --> <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan>
就是该原因导致了我在开启事务时,手动回滚报错
报错:No transaction aspect-managed TransactionStatus in scope
找了半天的原因才发现