当前位置: 移动技术网 > IT编程>开发语言>Java > spring配置扫描多个包问题解析

spring配置扫描多个包问题解析

2019年07月19日  | 移动技术网IT编程  | 我要评论

废水处理设备厂家博鼎机电,ispanks,刘浪的故乡

spring 配置扫描多个包,有时候我们希望不同功能类型的包放在不同的包下,这就需要

<!-- 自动扫描该包,使 springmvc 为包下用了@controller注解的类是控制器 --> 
<context:component-scan base-package="com.weixiao.ssmcleardb.controller" /> 
<context:component-scan base-package="com.weixiao.listener" /> 

有时候我们可能遇到奇怪的问题,

新建了一个包,在这个包下面新建了一个类,也添加了注解,但启动的时候就是扫描不到,而其它的类又正常!

这就是你新建的包没有配置为自动扫描的原因。

比如我在 com.weixiao.listener 包下新建的一个类:

package com.weixiao.listener;
import javax.servlet.servletcontext;
import org.apache.log4j.logmanager;
import org.apache.log4j.logger;
import org.springframework.beans.beansexception;
import org.springframework.beans.factory.initializingbean;
import org.springframework.context.applicationcontext;
import org.springframework.context.applicationcontextaware;
import org.springframework.context.applicationlistener;
import org.springframework.context.event.contextrefreshedevent;
import org.springframework.stereotype.component;
import org.springframework.web.context.servletcontextaware;
@component("startuplistener") 
public class startuplistener implements applicationcontextaware, servletcontextaware, initializingbean, 
    applicationlistener<contextrefreshedevent> {
	protected logger logger = logmanager.getlogger(getclass());
	@override 
	  public void setapplicationcontext(applicationcontext ctx) throws beansexception {
		logger.info("\r\n\r\n\r\n\r\n1 => startuplistener.setapplicationcontext");
	}
	@override 
	  public void setservletcontext(servletcontext context) {
		logger.info("\r\n\r\n\r\n\r\n2 => startuplistener.setservletcontext");
	}
	@override 
	  public void afterpropertiesset() throws exception {
		logger.info("\r\n\r\n\r\n\r\n3 => startuplistener.afterpropertiesset");
	}
	@override 
	  public void onapplicationevent(contextrefreshedevent event) {
		logger.info("\r\n\r\n\r\n\r\n4.1 => myapplicationlistener.onapplicationevent");
		logger.info("\r\n\r\n\r\n\r\n4.1 => " + event.getapplicationcontext().getparent());
		logger.info("\r\n\r\n\r\n\r\n4.1 => " + event.getapplicationcontext().getdisplayname());
		if (event.getapplicationcontext().getparent() == null) {
			logger.info("\r\n\r\n\r\n\r\n4.2 => myapplicationlistener.onapplicationevent");
		} else{
			logger.info("\r\n\r\n\r\n\r\n4.4 => " + event.getapplicationcontext().getparent().getdisplayname());
		}
		if (event.getapplicationcontext().getdisplayname().equals("root webapplicationcontext")){
			logger.info("\r\n\r\n\r\n\r\n4.3 => myapplicationlistener.onapplicationevent");
		}
	}
}

关于 component-scan,我们来看 spring framework 开发手册中的一段话:

spring 2.5引入了更多典型化注解(stereotype annotations): @component、@service和 @controller。@component是所有受spring管理组件的通用形式;而@repository、@service和 @controller则是@component的细化,用来表示更具体的用例(例如,分别对应了持久化层、服务层和表现层)。也就是说,你能用@component来注解你的组件类,但如果用@repository、@service 或@controller来注解它们,你的类也许能更好地被工具处理,或与切面进行关联。例如,这些典型化注解可以成为理想的切入点目标。当然,在spring framework以后的版本中, @repository、@service和 @controller也许还能携带更多语义。如此一来,如果你正在考虑服务层中是该用@component还是@service,那@service显然是更好的选择。同样的,就像前面说的那样, @repository已经能在持久化层中进行异常转换时被作为标记使用了。” 

总结

以上就是本文关于spring配置扫描多个包问题解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:spring配置使用之bean生命周期详解浅谈spring的两种配置容器等,有什么问题可以随时留言,小编会及时回复大家的。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网