我正在将Weblogic server从9升级到10.3.6。当我试图部署我的ear应用程序时,出现以下异常。
Caused By: java.lang.ClassCastException: org.apache.xerces.jaxp.DocumentBuilderFactoryImpl cannot be cast to javax.xml.parsers.DocumentBuilderFactory
at javax.xml.parsers.DocumentBuilderFactory.newInstance(DocumentBuilderFactory.java:123)
at org.springframework.beans.factory.xml.DefaultDocumentLoader.createDocumentBuilderFactory(DefaultDocumentLoader.java:89)
at org.springframework.beans.factory.xml.DefaultDocumentLoader.loadDocument(DefaultDocumentLoader.java:70)
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:396)
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:342)
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:310)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:143)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:178)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:149)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:212)
at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:113)
at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:80)
at org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:123)
at org.springframework.context.support.AbstractApplicationContext.obtainFreshBeanFactory(AbstractApplicationContext.java:423)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:353)
at org.springframework.context.access.ContextSingletonBeanFactoryLocator.initializeDefinition(ContextSingletonBeanFactoryLocator.java:141)
at org.springframework.beans.factory.access.SingletonBeanFactoryLocator.useBeanFactory(SingletonBeanFactoryLocator.java:384)
at org.springframework.web.context.ContextLoader.loadParentContext(ContextLoader.java:341)
at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:195)
at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:45)
at weblogic.servlet.internal.EventsManager$FireContextListenerAction.run(EventsManager.java:481)
at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:120)
at weblogic.servlet.internal.EventsManager.notifyContextCreatedEvent(EventsManager.java:181)
at weblogic.servlet.internal.WebAppServletContext.preloadResources(WebAppServletContext.java:1868)
我尝试了各种各样的方法,包括添加一个weblogic应用程序.xml但它仍然不起作用。
<?xml version="1.0" encoding="UTF-8"?>
<weblogic-application>
<xml>
<parser-factory>
<saxparser-factory>
org.apache.xerces.jaxp.SAXParserFactoryImpl
</saxparser-factory>
<document-builder-factory>
org.apache.xerces.jaxp.DocumentBuilderFactoryImpl
</document-builder-factory>
<transformer-factory>
org.apache.xalan.processor.TransformerFactoryImpl
</transformer-factory>
</parser-factory>
</xml>
<prefer-application-packages>
<package-name>org.apache.xerces.parsers.*</package-name>
</prefer-application-packages>
</weblogic-application>
我的weblogic.xml
<prefer-web-inf-classes>true</prefer-web-inf-classes>
这是我的pom.xml的一部分:
<dependency>
<groupId>xerces</groupId>
<artifactId>xercesImpl</artifactId>
<version>2.8.1</version>
<scope>runtime</scope>
</dependency>
请帮帮忙。谢谢!
我也有类似的问题。我使用的是安装在服务器上的应用程序。问题是我必须将xerces JAR放在应用程序的框架和第三方lib文件夹中。经过大量研究,我在xerces的文档中找到了解决方案。
为什么当我使用 Xerces 和 WebSphere Application Server 时,我会得到一个 ClassCastException?Xerces使用ObjectFactory类来动态加载一些类,例如解析器配置。ObjectFactory 通过查询系统属性、读取 META-INF/services/factoryId 文件或使用回退类名来查找指定的实现类。找到实现后,ObjectFactory 会尝试使用上下文类装入器装入文件,如果它为 null,则 ObjectFactory 将使用系统类装入器。如果您在具有多个类装入器的环境中运行 Xerces,例如 WebSphere® Application Server,您可能会得到从 Xerces 抛出的 ClassCastException,因为不同的类装入器可能会参与装入 Xerces 类。例如,当使用 Xerces 的实用程序 EAR 类从 WAR 模块加载 Xerces 类时,可能会发生 ClassCastException。我们建议您阅读“避免ClassCastExceptions...”文章介绍了此问题的解决方法。此外,您可能还想阅读“J2EE 类装入揭秘”一文,其中解释了多个类装入器如何在 WebSphere Application Server 中工作。
"
基本上,使用两个util类来创建domparser对象。对于来自应用程序的服务调用,更改类加载器并创建对象。完成处理后,返回类加载器。
ClassLoader savedClassLoader = Thread.currentThread().getContextClassLoader();
ClassLoader currentClassLoader = this.getClass().getClassLoader() ;
Thread.currentThread().setContextClassLoader(currentClassLoader);
//do the processing, after that revert back
https://xerces.apache.org/xerces2-j/faq-general.ht
我回答我自己的问题:
下面的链接激发了我修复此问题的灵感:
在Java/Maven中处理“Xerces地狱”?
基本上,我已经删除了pom.xml中xml-api和xmlParserAPI的所有依赖项。问题已修复。根本原因是我的类路径不应该包含任何导致库与Weblogic应用程序服务器冲突的javax库。希望它有帮助。