1018
微軟
windows
產生 java.lang.NoClassDefFoundError 的另一種意外情況:jar包部分的物理性損壞
產生 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: Error creating bean with name 'xxxService' defined in class path resource [META-INF/xfire/services.xml]: Invocation of init method failed; nested exception is java.lang.NoClassDefFoundError: org/apache/ws/commons/schema/XmlSchemaSimpleTypeList
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1174)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:425)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:251)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:156)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:248)
Truncated. see log file for complete stacktrace
java.lang.NoClassDefFoundError: org/apache/ws/commons/schema/XmlSchemaSimpleTypeList
at org.apache.ws.commons.schema.XmlSchemaCollection.read(XmlSchemaCollection.java:314)
at org.codehaus.xfire.wsdl11.parser.WSDLServiceConfigurator.setWrapped(WSDLServiceConfigurator.java:126)
at org.codehaus.xfire.wsdl11.parser.WSDLServiceConfigurator.<init>(WSDLServiceConfigurator.java:83)
at org.codehaus.xfire.service.binding.ObjectServiceFactory.create(ObjectServiceFactory.java:243)
at org.codehaus.xfire.service.binding.ObjectServiceFactory.create(ObjectServiceFactory.java:193)
Truncated. see log file for complete stacktrace
>
百思不得其解,通過 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 新的文件來替換掉它,重新打包部署就可以了。
最後更新:2017-04-02 00:06:25