Tomcat中的“Error listenerStart”错误信息:asm与cglib的版本兼容问题

来源:互联网 发布:淘宝联盟需要交钱吗 编辑:程序博客网 时间:2024/06/05 00:41

tomcat启动以后,webapp没有正常部署,检查tomcat控制台,发现如下打印信息:

二月 28, 2014 7:07:16 下午 org.apache.catalina.core.StandardContext startInternal

严重: Error listenerStart


再检查log日志,发现有如下错误信息:

严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListenerorg.springframework.beans.factory.BeanCreationException: Error creating bean with name 'hibernateSessionFactory' defined in ServletContext resource [/WEB-INF/classes/spring/hibernate/hibernate.xml]: Invocation of init method failed; nested exception is java.lang.NoSuchMethodError: org.objectweb.asm.ClassWriter.<init>(Z)Vat org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1455)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:294)...Caused by: java.lang.NoSuchMethodError: org.objectweb.asm.ClassWriter.<init>(Z)Vat net.sf.cglib.core.DebuggingClassWriter.<init>(DebuggingClassWriter.java:47)at net.sf.cglib.core.DefaultGeneratorStrategy.getClassWriter(DefaultGeneratorStrategy.java:30)at net.sf.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:24)....
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1452)... 25 more

从打印信息看,是在DebuggingClassWriter初始化过程中出错的。找到47行出错的地方:

       super(computeMaxs);

因为DebuggingClassWriter的父类是org.objectweb.asm.ClassWriter,检查源代码,发现使用的包中,该类没有对应的构造函数(boolean型),只有Int型。由此判断,应该是引用的包版本不兼容。检查了一下使用的包:cglib-2.1_3.jar和asm-3.3.jar。asm版本太新,回退到1.5.3就可以了。

这个错误的包是怎么引起的呢?

原来在pom.xml中没有定义asm,系统自动下载了3.3版本。在pom中重新添加:

<dependency><groupId>asm</groupId><artifactId>asm</artifactId><version>1.5.3</version></dependency>


问题解决。

0 0
原创粉丝点击