原创

Spring基础篇(二)—常见的Spring异常分析及处理

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

timg.jpg


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

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,修改一下配置文件名字即可。

<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:com/yoodb/config/testAjax.xml</param-value>
</init-param>


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、找不到jackson.jar的异常

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

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


4、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对象。


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.1.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 <beans> 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)}

解决方法:在配置文件中的<beans>根节点下加default-autowire="byName" default-lazy-init="true"或者<context:component-scan base-package="com.xxx.dao.*"></context:component-scan>包下面用*匹配 


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条件顺序。

关注下方微信公众号“Java精选”(w_z90110),回复关键字领取资料:如MysqlHadoopDubboCAS源码等等,免费领取视频教程、资料文档和项目源码。

涵盖:程序人生、搞笑视频、算法与数据结构、黑客技术与网络安全、前端开发、JavaPythonRedis缓存、Spring源码、各大主流框架、Web开发、大数据技术、StormHadoopMapReduceSparkElasticSearch、单点登录统一认证、分布式框架、集群、安卓开发、iOS开发、C/C++.NETLinuxMysqlOracleNoSQL非关系型数据库、运维等。

评论

分享:

支付宝

微信