Spring使用ComponentScan扫描Maven多模块工程的其它模块

说明:在新建好了Maven多模块工程后,如果想要在其它模块也能使用Spring的对象管理,比如@Autowrited这些注入方式,那么就必须开启包扫描的功能才能使其进行注入到Spring的对象管理中。

解决方法:

1、在Spring中配置ComponentScan的扫描包范围,把要加入的的Module包路径添加进去即可实现注入。

解释:

一、对于XML的配置:

在XML配置了这个标签后,Spring可以自动去扫描base-pack下面或者子包下面的java文件,如果扫描到有@Component @[email protected]等这些注解的类,则把这些类注册为Bean。

注意:如果配置了<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="com.jsoft.web"/>

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

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

<context:component-scan base-package="com.jsoft.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="com.jsoft.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>指定的扫描范围。

二、对于注解方式的使用,多数用于Spring Boot项目或者零配置的Spring MVC项目

其实本质都是一样的,只是写法不一样而已。

@EnableAutoConfiguration:

根据项目所使用的依赖自动进行配置。同时使用这个注解时,会默认在项目启动时扫描当前包及其子包下。同时也可以在@CompentScan注解中配置baskPackage属性来完成设置。如果自动完成的配置中包含了我们不需要的部分,则可以使用注解中的exclude属性来剔除。

@CompentScan: 

配置自动扫描,如果不配置任何属性则扫描当前包及其子包

@Configuration:

此注解标注了一个类为配置类。在使用SpringBoot时不需要在一个类中完成所有的配置。可以通过此注解标注并使该类可以被扫描,或者使用@Import注解来进行导入配置。另外,在使用xml来进行配置时可以通过使用@ImportResource来导入。

@SpringBootApplication:

相当于默认配置下的@[email protected][email protected],因为这三个注解经常同时使用,所以Spring给了一个简单的方式来完成使用。

参考:

http://blog.csdn.net/fewmore/article/details/50725412(以上内容部分转自此篇文章)

http://blog.csdn.net/shenqingxiao/article/details/53897255(以上内容部分转自此篇文章)

https://stackoverflow.com/questions/46784051/spring-boot-multi-module-project-load-property-file

https://stackoverflow.com/questions/12961394/how-to-autowire-service-in-another-module

https://stackoverflow.com/questions/34941862/spring-boot-configuration-in-a-multi-module-maven-project

https://stackoverflow.com/questions/33229793/how-to-add-multiple-application-properties-files-in-spring-boot

https://stackoverflow.com/questions/40384056/consider-defining-a-bean-of-type-package-in-your-configuration-spring-boot

https://www.cnblogs.com/maybo/p/5189516.html

http://blog.csdn.net/xieyuooo/article/details/9089441

http://blog.csdn.net/u011659172/article/details/51323066

http://jinnianshilongnian.iteye.com/blog/1762632

https://stackoverflow.com/questions/30970748/multiple-componentscan-in-spring-4

https://www.jianshu.com/p/752e2ba89dc3

http://blog.csdn.net/u013041642/article/details/78934157

http://blog.csdn.net/wolf2s/article/details/64473922

http://blog.csdn.net/ttjxtjx/article/details/49866011

原文地址:https://www.cnblogs.com/EasonJim/p/8320674.html

时间: 2024-11-10 16:23:05

Spring使用ComponentScan扫描Maven多模块工程的其它模块的相关文章

SSM(Spring MVC +Spring+Mybatis)整合——maven工程

所谓的SSM 其实就是Spring MVC下整合mybatis. 具体的定义网络上都有,很详细. 这里只说项目的搭建步骤. 第一步 新建maven工程 工程目录如下: 配置pom.xml文件,引入所需的jar包 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=&q

基于tomcat插件的maven多模块工程热部署

内容属原创,转载请注明出处 写在前面的话 最近一直比较纠结,归根结底在于工程的模块化拆分.以前也干过这事,但是一直对以前的结果不满意,这会重操旧业,希望搞出个自己满意的结果. 之前有什么不满意的呢? 1. 基于maven拆分模块后,热部署的效果不好,经常出故障. 2. 对于多个子web工程,不能做到任意一个web工程都可以放到tomcat里运行,要在外面搞个壳子组合多个工程. 于是,有了这纠结的一周,也有了此文. 本文关于什么 如标题所言,本文涉及到如下几个内容: 1. maven多模块工程 2

maven创建web工程Spring配置文件找不到问题解决方案

使用maven创建web工程,将Spring配置文件applicationContext.xml放在src/resource下,用eclipse编译时提示class path resource [applicationContext.xml] cannot be opened because it does not exist错误.但是用mvn clean package命令编译时成功的.web.xml配置的如下 <context-param><param-name>context

项目构建之maven篇:8.maven发布web工程及基于spring mvc,jetty实现的用户管理demo

web工程目录结构 pom/pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd&qu

【建项目】eclipse maven建立多模块工程

在工作的时候,大多时候都是用Maven来管理项目,可是一般我们都知道怎么用maven管理工程,却不知道通过Maven自己来建立多模块工程.于是自己抽时间,在网上找些资料,做了起来. 建立简单的Maven模块结构是这样的: ---- mv-parent |-- pom.xml (pom) | |-- mv-xml |        |-- pom.xml (jar) | |-- mv-lib |        |-- pom.xml (jar) | |-- mv-core |        |--

spring启动component-scan类扫描加载过程---源码分析

有朋友最近问到了 spring 加载类的过程,尤其是基于 annotation 注解的加载过程,有些时候如果由于某些系统部署的问题,加载不到,很是不解!就针对这个问题,我这篇博客说说spring启动过程,用源码来说明,这部分内容也会在书中出现,只是表达方式会稍微有些区别,我将使用spring 3.0的版本来说明(虽然版本有所区别,但是变化并不是特别大),另外,这里会从WEB中使用spring开始,中途会穿插自己通过newClassPathXmlApplicationContext 的区别和联系.

Maven:Eclipse导入从SVN上检出的Maven多模块工程

大致步骤: 1.从SVN中检出多模块项目,名称随意(Eclipse中可以在[Window ==>>Show View==>>Other==>>SVN==>>SVN资源库]中找到这个视图). 导出之后可以看到只是maven工程,而并非多模块工程. 2.导入Maven多模块工程 先把项目删掉(物理上不删),即右键delete,或者直接delete.然后再[Import==>>Existing Maven Projects],找到刚才的项目,导入即可.

spring启动component-scan类扫描加载过程(转)

文章转自 http://www.it165.net/pro/html/201406/15205.html 有朋友最近问到了 spring 加载类的过程,尤其是基于 annotation 注解的加载过程,有些时候如果由于某些系统部署的问题,加载不到,很是不解!就针对这个问题,我这篇博客说说spring启动过程,用源码来说明,这部分内容也会在书中出现,只是表达方式会稍微有些区别,我将使用spring 3.0的版本来说明(虽然版本有所区别,但是变化并不是特别大),另外,这里会从WEB中使用spring

多工程:基于Maven的SSM(Spring,SpringMvc,Mybatis)整合的web工程(中)

上篇用了单工程创建了SSM整合的web工程(http://www.cnblogs.com/yuanjava/p/6748956.html),这次我们把上篇的单工程改造成为多模块工程 一:创建对应的多工程 首先原工程有对应的包如下 因为原单工程是 contoller 调用 service ,service 调用 mapper ,mapper 调用pojo 因此把对应的 service  mapper  pojo 分别拆分出去当做模块  然后把utils公用的抽出去当做common模块 最后创建出来