spring自动装载mysql异常_Spring基础篇—常见的Spring异常分析及处理

本文总结了Spring框架在开发中常见的异常及其解决方法,包括404、400、500错误,配置文件找不到,Bean定义异常,缺少依赖jar包,以及事务和Bean加载问题等。针对每个异常,文章提供了详细的错误原因解释和相应的解决方案,旨在帮助开发者快速定位和修复问题。
摘要由CSDN通过智能技术生成

在实际开发工作中作为项目框架之一的Spring框架,相信我们经常会使用。然而在使用过程中,都会遇到很多的常见异常,本篇文章在这里总结一下,供大家参考借鉴。

78fa27e7b9bd0496b70982dea30d99ab.png

Spring默认会将自身抛出的异常自动映射到合适的状态码,如下是一些示例:

1f8a8abee3034b36d83b983dd79edd66.png

1)项目404:找不到目标资源(可能路径问题)

2)项目400:前端发送到后台的参数类型,和所请求的路由方法参数不匹配,此时consle控制台没有出错

3)项目500:consle出错

1、找不到配置文件的异常org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XML

document from class path resource [com/yoodb/controller]; nested exception is java.io.FileNotFoundException:

class path resource [com/yoodb/controller] cannot be opened because it does not exist

含义:没有找配置文件为controller的xml,修改一下配置文件名字即可。

contextConfigLocation

classpath:com/yoodb/config/testAjax.xml

2、在xml中配置的命名空间找不到对应的Schema的异常

nested exception is org.xml.sax.SAXParseException: cvc-complex-type.2.4.c: The matching wildcard is strict,

but no declaration can be found for element 'util:list'.

xmlns:util="http://www.springframework.org/schema/util" 去掉,因为schema中不存在util命名

3、bean不是唯一的异常org.springframework.beans.factory.NoUniqueBeanDefinitionException:

No qualifying bean of type [com.yoodb.pojo.Person] is defined:

expected single matching bean but found 7: person0,person1,person2,person3,person4,person5,person6

at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBean(DefaultListableBeanFactory.java:313)

at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:985)

at com.yoodb.test.Test0.test1(Test0.java:35)

at com.yoodb.test.Test0.main(Test0.java:111)

这个异常是说,一个类配置了多个bean之后,我们还在使用ctx.getBean(Person.class);方法,即根据bean的类映射去获取bean对象。这个时候返回的bean对象不是唯一的,有多个bean对象。解决方法,就是根据bean的id去获取bean对象。

4、找不到jackson.jar的异常StandardWrapper.Throwable

java.lang.NoClassDefFoundError: org/codehaus/jackson/JsonProcessingException

缺少jackson的jar包,导入jackson-all-1.9.5.jar即可

5、缺少日志jar包java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory

Caused by: java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory

这个问题是说,项目中缺少spring依赖的jar包文件。解决方法:加入commons-logging-1.1.3.jar即可。

6、找不到bean异常org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'filter2' is defined

这个问题是说,项目中找不到name为filter2的bean。说白了就是在applicationContext.xml中找不到id为filter2的bean,配置一下即可。

7、缺少spring-webmvc-4.1.6.RELEASE.jar包严重: Error loading WebappClassLoader

context: /Struts_Spring_Project

delegate: false

repositories:

/WEB-INF/classes/

----------> Parent Classloader:

org.apache.catalina.loader.StandardClassLoader@b33d0a

org.springframework.web.servlet.DispatcherServlet

java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet

解决方法:在项目中加入spring的mvc架包即可。如我的spring版本为4.0.6的,那么就把spring-webmvc-4.1.6.RELEASE.jar添加进去即可。

8、缺少spring-aop-4.1.6.RELEASE.jar包java.lang.NoClassDefFoundError: org/springframework/aop/TargetSource

java.lang.ClassNotFoundException: org.springframework.aop.TargetSource

解决方法:在项目中加入spring的aop架包即可。如我的spring版本为4.1.6的,那么就把spring-aop-4.1.6.RELEASE.jar添加进去即可。

9、缺少spring-expression-4.1.6.RELEASE.jar包java.lang.NoClassDefFoundError: org/springframework/expression/ExpressionParser

java.lang.ClassNotFoundException: org.springframework.expression.ExpressionParser

解决方法:在项目中加入spring的expression架包即可。如我的spring版本为4.1.6的,那么就把spring-expression-4.1.6.RELEASE.jar添加进去即可。

10、bean的名字name或者id或者别名alias已经存在org.springframework.beans.factory.parsing.BeanDefinitionParsingException:

Configuration problem: Bean name 'a' is already used in this  element

解决方法:把重复的名字改个名字即可。

11、bean的自动加载找不到相对应的bean问题org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.yoodb] 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)}

解决方法:在配置文件中的根节点下加default-autowire="byName" default-lazy-init="true"或者包下面用*匹配

12、spring事务超时transaction unexpectedly rolled back (maybe due to a timeout); nested exception is javax.transaction.RollbackException;

可能原因1:spring事务设置的时间比较短。

解决方法:把spring事务设置长一点,如果事务中有很多复杂的查询及更新操作,取消方法上的事务注解,然后把查询操作整理后放在方法最前面,把更新操作放在一块,用自定义事务把更新操作放进去。

可能原因2:可能是mysql数据库InnoDB使用缓冲池设置小了,事务隔离级别不对。

解决方法:把缓存mysql数据库InnoDB使用缓冲池设置大些,同时把事务隔离级别由默认的REPEATABLE_READ级别改为READ_COMMITTED(关于事务级别在这里不再描述);

可能原因3:查询、更新sql效率不高;

解决方法:加索引,注意根据不同的数据库编写不同的表及where条件顺序。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值