这个问题困扰我一个小时,项目使用的是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!