閱讀1018 返回首頁    go 微軟 go 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

  上一篇:go 誰偷走了我們的工資?
  下一篇:go 長征三號甲(CZ-3A)運載火箭概述