Error creating bean with name 'barchService': Injection of resource dependencies failed

这个问题困扰我一个小时,项目使用的是Sringmvc maven mybatis ,在service成使用@Service 老报错误创建bean失败,习惯性的去看错误,搞了半天,真是日*够了,看日志只看一半,直接上代码,记录下。


[o.m.s.mapper.ClassPathMapperScanner:158] - No MyBatis mapper was found in '[com.bug.dao]' package. Please check your configuration.
2018-05-21 10:04:55,607 INFO  [o.s.w.s.v.f.FreeMarkerConfigurer:127] - ClassTemplateLoader for Spring macros added to FreeMarker configuration
2018-05-21 10:04:55,701 WARN  [o.s.w.c.s.XmlWebApplicationContext:551] - Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'barchService': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.shgz.dao.BarchMapper' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@javax.annotation.Resource(shareable=true, lookup=, name=, description=, authenticationType=CONTAINER, type=class java.lang.Object, mappedName=)}
2018-05-21 10:04:55,701 ERROR [o.s.web.servlet.DispatcherServlet:502] - Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'barchService': Injection of resource dependencies failed; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.shgz.dao.BarchMapper' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@javax.annotation.Resource(shareable=true, lookup=, name=, description=, authenticationType=CONTAINER, type=class java.lang.Object, mappedName=)}
	at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessPropertyValues(CommonAnnotationBeanPostProcessor.java:321)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1264)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:553)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:483)
	at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306)
	at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
	at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302)
	at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197)

看第一行

No MyBatis mapper was found in '[com.bug.dao]' package. Please check your configuration.

这个明确告诉我们找不到这个路径,而一半创建bean失败,大概就是目录没有扫描到找出的,只要去关注扫描路径就好

,为什么会出现这个问题呢?这个项目是我从自己之前的项目拷贝过来修改的,建包的时候没有太注意出的问题,真是......,修改如下:

 <!-- mybatis的配置文件 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="mapperLocations" value="classpath*:com/shgz/dao/mapper/*.xml"/>
    </bean>

    <!-- spring与mybatis整合配置,扫描所有dao -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.shgz.dao"/>
    </bean>
再启动看下:
[2018-05-21 10:19:51,885] Artifact SPIMS:war exploded: Artifact is deployed successfully
[2018-05-21 10:19:51,885] Artifact SPIMS:war exploded: Deploy took 5,423 milliseconds
五月 21, 2018 10:19:56 上午 org.apache.catalina.startup.HostConfig deployDirectory

到此,no problem!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值