【问题标题】:ClassCastException running Spring app on Weblogic 9.2在 Weblogic 9.2 上运行 Spring 应用程序的 ClassCastException
【发布时间】:2010-10-22 22:27:56
【问题描述】:

我正在尝试将 Spring 3 应用程序部署到 Weblogic 9.2。 JDK 是 JRockit 1.5。我正在使用 jaxb 2.1,并且在战争中包括了那些罐子。

我尝试将其添加到 weblogic.xml 中,认为我包含的内容与运行它的环境之间存在冲突。

<wls:container-descriptor>
  <wls:prefer-web-inf-classes>true</wls:prefer-web-inf-classes>
</wls:container-descriptor>

仍然没有运气。我是在做一些被禁止的事情,还是只是缺少一个关键的配置?

如果我遗漏了相关内容,请询问。提前致谢。

这是错误:

 [wldeploy] java.lang.ClassCastException: weblogic.xml.jaxp.RegistryDocumentBuilderFactory
 [wldeploy]   at javax.xml.parsers.DocumentBuilderFactory.newInstance(Unknown Source)
 [wldeploy]   at org.springframework.beans.factory.xml.DefaultDocumentLoader.createDocumentBuilderFactory(DefaultDocumentLoader.java:87)
 [wldeploy]   at org.springframework.beans.factory.xml.DefaultDocumentLoader.loadDocument(DefaultDocumentLoader.java:68)
 [wldeploy]   at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:361)
 [wldeploy]   at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:313)
 [wldeploy]   at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:290)
 [wldeploy]   at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:131)
 [wldeploy]   at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:147)
 [wldeploy]   at org.springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:124)
 [wldeploy]   at org.springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:92)
 [wldeploy]   at org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:101)
 [wldeploy]   at org.springframework.context.support.AbstractApplicationContext.obtainFreshBeanFactory(AbstractApplicationContext.java:394)
 [wldeploy]   at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:324)
 [wldeploy]   at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:246)
 [wldeploy]   at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:189)
 [wldeploy]   at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:49)
 [wldeploy]   at weblogic.servlet.internal.EventsManager$FireContextListenerAction.run(EventsManager.java:376)
 [wldeploy]   at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
 [wldeploy]   at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:121)
 [wldeploy]   at weblogic.servlet.internal.EventsManager.notifyContextCreatedEvent(EventsManager.java:82)
 [wldeploy]   at weblogic.servlet.internal.WebAppServletContext.preloadResources(WebAppServletContext.java:1608)
 [wldeploy]   at weblogic.servlet.internal.WebAppServletContext.start(WebAppServletContext.java:2750)
 [wldeploy]   at weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:889)
 [wldeploy]   at weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:333)
 [wldeploy]   at weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:204)
 [wldeploy]   at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:26)
 [wldeploy]   at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:60)
 [wldeploy]   at weblogic.application.internal.flow.ScopedModuleDriver.start(ScopedModuleDriver.java:200)
 [wldeploy]   at weblogic.application.internal.flow.ModuleListenerInvoker.start(ModuleListenerInvoker.java:117)
 [wldeploy]   at weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:204)
 [wldeploy]   at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:26)
 [wldeploy]   at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:60)
 [wldeploy]   at weblogic.application.internal.flow.StartModulesFlow.activate(StartModulesFlow.java:26)
 [wldeploy]   at weblogic.application.internal.BaseDeployment$2.next(BaseDeployment.java:635)
 [wldeploy]   at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:26)
 [wldeploy]   at weblogic.application.internal.BaseDeployment.activate(BaseDeployment.java:212)
 [wldeploy]   at weblogic.application.internal.DeploymentStateChecker.activate(DeploymentStateChecker.java:154)
 [wldeploy]   at weblogic.deploy.internal.targetserver.AppContainerInvoker.activate(AppContainerInvoker.java:80)
 [wldeploy]   at weblogic.deploy.internal.targetserver.operations.AbstractOperation.activate(AbstractOperation.java:566)
 [wldeploy]   at weblogic.deploy.internal.targetserver.operations.ActivateOperation.activateDeployment(ActivateOperation.java:136)
 [wldeploy]   at weblogic.deploy.internal.targetserver.operations.ActivateOperation.doCommit(ActivateOperation.java:104)
 [wldeploy]   at weblogic.deploy.internal.targetserver.operations.AbstractOperation.commit(AbstractOperation.java:320)
 [wldeploy]   at weblogic.deploy.internal.targetserver.DeploymentManager.handleDeploymentCommit(DeploymentManager.java:815)
 [wldeploy]   at weblogic.deploy.internal.targetserver.DeploymentManager.activateDeploymentList(DeploymentManager.java:1222)
 [wldeploy]   at weblogic.deploy.internal.targetserver.DeploymentManager.handleCommit(DeploymentManager.java:433)
 [wldeploy]   at weblogic.deploy.internal.targetserver.DeploymentServiceDispatcher.commit(DeploymentServiceDispatcher.java:161)
 [wldeploy]   at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.doCommitCallback(DeploymentReceiverCallbackDeliverer.java:181)
 [wldeploy]   at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.access$100(DeploymentReceiverCallbackDeliverer.java:12)
 [wldeploy]   at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer$2.run(DeploymentReceiverCallbackDeliverer.java:67)
 [wldeploy]   at weblogic.work.ExecuteRequestAdapter.execute(ExecuteRequestAdapter.java:21)
 [wldeploy]   at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:145)
 [wldeploy]   at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:117)

【问题讨论】:

    标签: java spring weblogic


    【解决方案1】:

    似乎ClassCastException 是类加载冲突的结果。

    您说您正在将一些 JAR 文件与您的 Web 应用程序捆绑在一起(我假设在 WEB-INF/lib 中);我怀疑发生的情况是 weblogic.xml.jaxp.RegistryDocumentBuilderFactory,它是 WebLogic 的 DocumentBuilderFactory 实现,由不同的类加载器加载,而不是加载其接口之一(或其超类,即 JAXP 的 DocumentBuilderFactory)的类加载器。

    让我们知道您在 WEB-INF/lib 中打包了哪些 JAR 文件;我很确定罪魁祸首在那里。

    【讨论】:

    • 这是现在的内容:stax-api-1.0.2、spring-web-3.0.2、spring-tx-3.0.2、spring-jms-3.0.2、spring- jdbc-3.0.2、spring-expression-3.0.2、spring-core-3.0.2、spring-context-3.0.2、spring-beans-3.0.2、spring-asm-3.0.2、spring-aop- 3.0.2、mysql-connector-java-5.1.13、jaxb-xjc-2.1.9、jaxb-impl-2.1.9、jaxb-api-2.1、commons-pool-1.5.4、commons-logging-1.1。 1、commons-dbcp-1.3、aopalliance-1.0、activemq-all-5.1.0、activation-1.1
    • 有没有这个课程? javax.xml.parsers.DocumentBuilderFactory
    • 有趣。根据堆栈跟踪,javax.xml.parsers.DocumentBuilderFactory.newInstance(这是 JAXP 的工厂方法,创建 DocBuilders)正在尝试实例化 WebLogic 指定为 DocBuilder 工厂的类。它找到了类。 ClassCastException 表示相关的 WebLogic JAXP 类已经被加载,但在不同的类加载器中。我得考虑一下。您可以尝试将系统属性jaxp.debug 设置为true 并再试一次吗?
    猜你喜欢
    • 1970-01-01
    • 2011-01-12
    • 1970-01-01
    • 2018-05-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多