java - 部署错误 - ServletWrapper 失败 : java. lang.NoSuchMethodError : javax. persistence.OneToMany.orphanRemoval()Z

标签 java hibernate jpa weblogic

我正在部署一个应用程序,在启动过程中我收到以下消息:

<Warning> <HTTP> <brvix5valeas213> <ocr_dev_ms01> <[STANDBY] ExecuteThread: '4' for queue:     'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <> <1404137636050> <BEA-101162> <User defined listener play.server.ServletWrapper failed: java.lang.NoSuchMethodError: javax.persistence.OneToMany.orphanRemoval()Z.
java.lang.NoSuchMethodError: javax.persistence.OneToMany.orphanRemoval()Z
at org.hibernate.cfg.AnnotationBinder.processElementAnnotations(AnnotationBinder.java:1912)
at org.hibernate.cfg.AnnotationBinder.processIdPropertiesIfNotAlready(AnnotationBinder.java:796)
at org.hibernate.cfg.AnnotationBinder.bindClass(AnnotationBinder.java:707)
at org.hibernate.cfg.Configuration$MetadataSourceQueue.processAnnotatedClassesQueue(Configuration.java:4035)
at org.hibernate.cfg.Configuration$MetadataSourceQueue.processMetadata(Configuration.java:3989)
at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1398)
at org.hibernate.cfg.Configuration.buildMappings(Configuration.java:1375)
at org.hibernate.ejb.Ejb3Configuration.buildMappings(Ejb3Configuration.java:1519)
at org.hibernate.ejb.EventListenerConfigurator.configure(EventListenerConfigurator.java:193)
at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:1100)
at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:904)
at play.db.jpa.JPAPlugin.onApplicationStart(JPAPlugin.java:267)
at play.plugins.PluginCollection.onApplicationStart(PluginCollection.java:525)
at play.Play.start(Play.java:526)
at play.Play.init(Play.java:300)
at play.server.ServletWrapper.contextInitialized(ServletWrapper.java:78)
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:1872)
at weblogic.servlet.internal.WebAppServletContext.start(WebAppServletContext.java:3153)
at weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:1508)
at weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:482)
at weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:425)
at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52)
at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:119)
at weblogic.application.internal.flow.ScopedModuleDriver.start(ScopedModuleDriver.java:200)
at weblogic.application.internal.flow.ModuleListenerInvoker.start(ModuleListenerInvoker.java:247)
at weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:425)
at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52)
at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:119)
at weblogic.application.internal.flow.StartModulesFlow.activate(StartModulesFlow.java:27)
at weblogic.application.internal.BaseDeployment$2.next(BaseDeployment.java:636)
at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52)
at weblogic.application.internal.BaseDeployment.activate(BaseDeployment.java:205)
at weblogic.application.internal.SingleModuleDeployment.activate(SingleModuleDeployment.java:43)
at weblogic.application.internal.DeploymentStateChecker.activate(DeploymentStateChecker.java:161)
at weblogic.deploy.internal.targetserver.AppContainerInvoker.activate(AppContainerInvoker.java:79)
at weblogic.deploy.internal.targetserver.operations.AbstractOperation.activate(AbstractOperation.java:569)
at weblogic.deploy.internal.targetserver.operations.ActivateOperation.activateDeployment(ActivateOperation.java:150)
at weblogic.deploy.internal.targetserver.operations.ActivateOperation.doCommit(ActivateOperation.java:116)
at weblogic.deploy.internal.targetserver.operations.StartOperation.doCommit(StartOperation.java:140)
at weblogic.deploy.internal.targetserver.operations.AbstractOperation.commit(AbstractOperation.java:323)
at weblogic.deploy.internal.targetserver.DeploymentManager.handleDeploymentCommit(DeploymentManager.java:844)
at weblogic.deploy.internal.targetserver.DeploymentManager.activateDeploymentList(DeploymentManager.java:1253)
at weblogic.deploy.internal.targetserver.DeploymentManager.handleCommit(DeploymentManager.java:440)
at weblogic.deploy.internal.targetserver.DeploymentServiceDispatcher.commit(DeploymentServiceDispatcher.java:163)
at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.doCommitCallback(DeploymentReceiverCallbackDeliverer.java:195)
at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.access$100(DeploymentReceiverCallbackDeliverer.java:13)
at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer$2.run(DeploymentReceiverCallbackDeliverer.java:68)
at weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run(SelfTuningWorkManagerImpl.java:528)
at weblogic.work.ExecuteThread.execute(ExecuteThread.java:209)
at weblogic.work.ExecuteThread.run(ExecuteThread.java:178)

我在 Google 上尝试了很多建议,但没有成功。进一步信息:

  • WL 10.3.5
  • Windows 2008 R2 64 位
  • JDK 7u9
  • 控制台和节点管理器作为 Windows 服务

  • 应用程序需要 JPA2。在类路径中包含“D:\app\oracle\wls1035\modules\javax.persistence_1.0.0.0_2-0-0.jar”。

  • 开发环境和生产环境均无法运行。
  • 应用程序使用您自己的库,在 weblogic.xml 上的 Preferred-web-inf-classes=true 下定义
  • 所有 hibernate 文件都包含在应用程序 lib 文件夹中

最佳答案

定义“OneToMany”的类路径有多个依赖项。有些东西正在使用旧版本的 javax.persistence。只需在出现错误之前添加此行代码并查看打印内容:

System.out.println(javax.persistence.OneToMany.class.getProtectionDomain().getCodeSource().getLocation());

打印的 JAR 文件可能是罪魁祸首。您需要删除它或更新它以使用 javax.persistence-2.X.X。

关于java - 部署错误 - ServletWrapper 失败 : java. lang.NoSuchMethodError : javax. persistence.OneToMany.orphanRemoval()Z,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24496770/

相关文章:

java - 无法读取 Java Web 应用程序中的属性文件?

java - 我想排除 hibernate 注释中的字段

java - JPAController getReference BigDecimal 问题

postgresql - 使用谓词进行日期过滤的条件查询

java - 编译后的 Eclipse maven 在 Eclipse 中看不到目标/类文件夹

java - 将十六进制字节数组解码为特定代码页在随后编码时会带来错误的结果

java - Spring MVC 设置中的配置问题

java - 如何通过示例使用 hibernate 查询来搜索 Id?

java - 当外键不是对象本身的属性时,如何指定多对一关系上的外键?

java - 映射列的 JPA i18n 问题