场景:
我在学习SSM整合,和项目的时候经常遇到的问题,启动代码的时候从不报错,去浏览器上就开始报错了,也去网上找到了很多大家出现的问题
问题描述:
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'xxController': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: private com.a.service.yyService com.a.controller.xxController.xxService; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.a.service.yyService] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:326)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1204)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:538)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:476)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:302)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:229)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:298)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:193)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:725)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:757)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:480)
at org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.java:658)
at org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:624)
at org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:672)
at org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:543)
at org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:484)
at org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:136)
at javax.servlet.GenericServlet.init(GenericServlet.java:244)
at org.eclipse.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:517)
at org.eclipse.jetty.servlet.ServletHolder.getServlet(ServletHolder.java:399)
at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:644)
at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:449)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:138)
at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:564)
at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:213)
at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1070)
原因分析:
此异常为:注入 bean 失败异常,也就是说找不到对应的 bean。
我的第一反应是注解写错了,马上去找注解
能够导致 bean 注入失败的原因包括:
1、对应的 bean 没有添加注解、添加错误,或者选择错误的自动注入方法;
2、项目整合的时候jar包引用出错
3、配置有误(摁住ctrl去看这个路径能不能点)
解决方案:
1、bean注解问题
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class AService {
@Autowired
AMapper aMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
@Controller
@RequestMapping("/a")
public class AController {
@Autowired
private AService aService;
2、如果jar包冲突,检查一下jar包是否提示警告信息(对于我们这种小白来说,如果实在是不太能找出来,就把别人的复制来试一下,看看是不是这个问题,是的话就可以对一对啦,再关注一下版本问题)
3、配置文件出错
看看spring-core.xml 和spring-mvc.xml是否有问题
我的问题就是web.xml文件中
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
最后的ContextLoaderListener被我写成了ContextCleanupListener
这个问题被发现是因为我把(web.xml文件)下边这个的”classpath:“删掉了,错误不变,才找到的是现在的错误
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-core.xml</param-value>
</context-param>
总结:
出现org.springframework.beans.factory.BeanCreationException: Error creating bean with name问题就从三个方面下手
1、注解问题
2、jar包问题(版本等)
3、配置文件(spring-core.xml中的class,连接池有没有写错,spring-mvc.xml中扫描注解,映射器,处理器有没有写错。web.xml中很多路径有没有写错)