产生 java.lang.NoClassDefFoundError 的另一种意外情况:jar包部分的物理性损坏
环境:BEA WebLogic 9.2 MP1 + Spring 2.0.6 + XFire 1.2.8 + ...部署:部署时是以整个 ear 包进行项目部署,部署倒是完成可以成功,只是在调用 Web Services 时产生错误
org.springframework.beans.factory.BeanCreationException:Errorcreatingbeanwithname'xxxService'definedinclasspathresource[META-INF/xfire/services.xml]:Invocationofinitmethodfailed;nestedexceptionisjava.lang.NoClassDefFoundError:org/apache/ws/commons/schema/XmlSchemaSimpleTypeList
atorg.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1174)
atorg.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:425)
atorg.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:251)
atorg.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:156)
atorg.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:248)
Truncated.seelogfileforcompletestacktrace
java.lang.NoClassDefFoundError:org/apache/ws/commons/schema/XmlSchemaSimpleTypeList
atorg.apache.ws.commons.schema.XmlSchemaCollection.read(XmlSchemaCollection.java:314)
atorg.codehaus.xfire.wsdl11.parser.WSDLServiceConfigurator.setWrapped(WSDLServiceConfigurator.java:126)
atorg.codehaus.xfire.wsdl11.parser.WSDLServiceConfigurator.<init>(WSDLServiceConfigurator.java:83)
atorg.codehaus.xfire.service.binding.ObjectServiceFactory.create(ObjectServiceFactory.java:243)
atorg.codehaus.xfire.service.binding.ObjectServiceFactory.create(ObjectServiceFactory.java:193)
Truncated.seelogfileforcompletestacktrace
>
百思不得其解,通过 JarClassFind 查找 org/apache/ws/commons/schema/XmlSchemaSimpleTypeList 类,在 APP-INF\lib 目录下的确存在有包含这个类的包 XmlSchema-1.1.jar,但就是不行。而且在BEA的WebLogic目录及Domain目录下均没有发现包含这个类的其它jar包,可以排除 classloader 引起的一些问题了。
最后,用 WinRAR 打开 XmlSchema-1.1.jar 文件,也可以看到存在 XmlSchemaSimpleTypeList 这个类,于是尝试解压出来,在解压的过程中出错,于是问题找到了,找到一个 XmlSchema-1.1.jar 新的文件来替换掉它,重新打包部署就可以了。
本文探讨了一种罕见的情况:由于jar包物理损坏导致的java.lang.NoClassDefFoundError错误。详细介绍了如何诊断并最终定位到问题原因的过程,即jar包内的类文件实际上已损坏。
5792

被折叠的 条评论
为什么被折叠?



