jpa - EclipseLink 在尝试编织类时抛出 ArrayIndexOutOfBoundsException

标签 jpa playframework eclipselink

我有我提供 eclipselink-2.5.1.jar 代理的 Play Framework 应用程序 (2.3.8)。在启动期间,我在日志中看到:

Weaver encountered an exception while trying to weave class [one of my JPA entities class]. The exception was: java.lang.ArrayIndexOutOfBoundsException: 30053


  • 如何调查导致问题的原因?
  • 可能有什么问题?

  • 更新:
    因此,将日志记录更改为最好给了我一个堆栈跟踪:
    EL Finest]: weaver: 2015-07-16 20:52:31.163--ServerSession(1547425104)--Thread(Thread[application-akka.actor.default-dispatcher-2,5,main])--java.lang.ArrayIndexOutOfBoundsException: 25970
            at org.eclipse.persistence.internal.libraries.asm.ClassReader.readClass(Unknown Source)
            at org.eclipse.persistence.internal.libraries.asm.ClassReader.getInterfaces(Unknown Source)
            at org.eclipse.persistence.internal.jpa.weaving.ComputeClassWriter.typeImplements(ComputeClassWriter.java:143)
            at org.eclipse.persistence.internal.jpa.weaving.ComputeClassWriter.typeImplements(ComputeClassWriter.java:150)
            at org.eclipse.persistence.internal.jpa.weaving.ComputeClassWriter.getCommonSuperClass(ComputeClassWriter.java:62)
            at org.eclipse.persistence.internal.libraries.asm.ClassWriter.getMergedType(Unknown Source)
            at org.eclipse.persistence.internal.libraries.asm.Frame.merge(Unknown Source)
            at org.eclipse.persistence.internal.libraries.asm.Frame.merge(Unknown Source)
            at org.eclipse.persistence.internal.libraries.asm.MethodWriter.visitMaxs(Unknown Source)
            at org.eclipse.persistence.internal.libraries.asm.MethodAdapter.visitMaxs(Unknown Source)
            at org.eclipse.persistence.internal.jpa.weaving.MethodWeaver.visitMaxs(MethodWeaver.java:152)
            at org.eclipse.persistence.internal.libraries.asm.ClassReader.accept(Unknown Source)
            at org.eclipse.persistence.internal.libraries.asm.ClassReader.accept(Unknown Source)
            at org.eclipse.persistence.internal.jpa.weaving.PersistenceWeaver.transform(PersistenceWeaver.java:93)
            at org.eclipse.persistence.internal.jpa.deployment.JavaSECMPInitializer$1.transform(JavaSECMPInitializer.java:228)
            at sun.instrument.TransformerManager.transform(TransformerManager.java:188)
            at sun.instrument.InstrumentationImpl.transform(InstrumentationImpl.java:428)
            at java.lang.ClassLoader.defineClass1(Native Method)
            at java.lang.ClassLoader.defineClass(ClassLoader.java:760)
            at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
            at java.net.URLClassLoader.defineClass(URLClassLoader.java:455)
            at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
            at java.net.URLClassLoader$1.run(URLClassLoader.java:367)
            at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
            at java.security.AccessController.doPrivileged(Native Method)
            at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
            at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
            at java.lang.Class.forName0(Native Method)
            at java.lang.Class.forName(Class.java:340)
            at org.eclipse.persistence.internal.security.PrivilegedAccessHelper.getClassForName(PrivilegedAccessHelper.java:124)
            at org.eclipse.persistence.internal.jpa.metadata.listeners.EntityListenerMetadata.getClass(EntityListenerMetadata.java:224)
            at org.eclipse.persistence.internal.jpa.metadata.listeners.EntityClassListenerMetadata.process(EntityClassListenerMetadata.java:81)
            at org.eclipse.persistence.internal.jpa.metadata.accessors.classes.EntityAccessor.processListeners(EntityAccessor.java:1220)
            at org.eclipse.persistence.internal.jpa.metadata.MetadataProcessor.addEntityListeners(MetadataProcessor.java:138)
            at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.deploy(EntityManagerSetupImpl.java:591)
            at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.getAbstractSession(EntityManagerFactoryDelegate.java:204)
            at org.eclipse.persistence.internal.jpa.EntityManagerFactoryDelegate.createEntityManagerImpl(EntityManagerFactoryDelegate.java:304)
            at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManagerImpl(EntityManagerFactoryImpl.java:336)
            at org.eclipse.persistence.internal.jpa.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:302)
            at play.db.jpa.DefaultJPAApi.em(DefaultJPAApi.java:71)
            at play.db.jpa.DefaultJPAApi.withTransaction(DefaultJPAApi.java:123)
            at play.db.jpa.JPA.withTransaction(JPA.java:159)
            at play.db.jpa.TransactionalAction.call(TransactionalAction.java:16)
            at play.core.j.JavaAction$$anonfun$7.apply(JavaAction.scala:94)
            at play.core.j.JavaAction$$anonfun$7.apply(JavaAction.scala:94)
            at scala.concurrent.impl.Future$PromiseCompletingRunnable.liftedTree1$1(Future.scala:24)
            at scala.concurrent.impl.Future$PromiseCompletingRunnable.run(Future.scala:24)
            at play.core.j.HttpExecutionContext$$anon$2.run(HttpExecutionContext.scala:40)
            at play.api.libs.iteratee.Execution$trampoline$.execute(Execution.scala:70)
            at play.core.j.HttpExecutionContext.execute(HttpExecutionContext.scala:32)
            at scala.concurrent.impl.Future$.apply(Future.scala:31)
            at scala.concurrent.Future$.apply(Future.scala:485)
            at play.core.j.JavaAction.apply(JavaAction.scala:94)
            at play.api.mvc.Action$$anonfun$apply$1$$anonfun$apply$4$$anonfun$apply$5.apply(Action.scala:105)
            at play.api.mvc.Action$$anonfun$apply$1$$anonfun$apply$4$$anonfun$apply$5.apply(Action.scala:105)
            at play.utils.Threads$.withContextClassLoader(Threads.scala:21)
            at play.api.mvc.Action$$anonfun$apply$1$$anonfun$apply$4.apply(Action.scala:104)
            at play.api.mvc.Action$$anonfun$apply$1$$anonfun$apply$4.apply(Action.scala:103)
            at scala.Option.map(Option.scala:145)
            at play.api.mvc.Action$$anonfun$apply$1.apply(Action.scala:103)
            at play.api.mvc.Action$$anonfun$apply$1.apply(Action.scala:96)
            at play.api.libs.iteratee.Iteratee$$anonfun$mapM$1.apply(Iteratee.scala:524)
            at play.api.libs.iteratee.Iteratee$$anonfun$mapM$1.apply(Iteratee.scala:524)
            at play.api.libs.iteratee.Iteratee$$anonfun$flatMapM$1.apply(Iteratee.scala:560)
            at play.api.libs.iteratee.Iteratee$$anonfun$flatMapM$1.apply(Iteratee.scala:560)
            at play.api.libs.iteratee.Iteratee$$anonfun$flatMap$1$$anonfun$apply$13.apply(Iteratee.scala:536)
            at play.api.libs.iteratee.Iteratee$$anonfun$flatMap$1$$anonfun$apply$13.apply(Iteratee.scala:536)
            at scala.concurrent.impl.Future$PromiseCompletingRunnable.liftedTree1$1(Future.scala:24)
            at scala.concurrent.impl.Future$PromiseCompletingRunnable.run(Future.scala:24)
            at akka.dispatch.TaskInvocation.run(AbstractDispatcher.scala:40)
            at akka.dispatch.ForkJoinExecutorConfigurator$AkkaForkJoinTask.exec(AbstractDispatcher.scala:397)
            at scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260)
            at scala.concurrent.forkjoin.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1339)
            at scala.concurrent.forkjoin.ForkJoinPool.runWorker(ForkJoinPool.java:1979)
            at scala.concurrent.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107)
    

    但对我来说帮助不大。

    最佳答案

    这看起来像是 EclipseLink 在处理 lambda 表达式时使用的 ASM 处理器中的错误。错误 https://bugs.eclipse.org/bugs/show_bug.cgi?id=429992已在 EclipseLink 2.6 中修复。

    关于jpa - EclipseLink 在尝试编织类时抛出 ArrayIndexOutOfBoundsException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31218544/

    相关文章:

    java - JPA:如何保持多对多关系

    java - 使用 EclipseLink 自定义 JPA 字段名称映射

    hibernate - 使用 CriteriaQuery 和 EntityManager(Hibernate) 进行查询

    java - Spring boot + Hibernate + JPA 没有可用的事务性 EntityManager

    playframework - Play中的内容安全策略 header !框架

    scala - Play WS - 检查压缩头

    jpa - 在 PlayFramework 2/Ebean ORM 中使用@OneToOne,其中 child 和 parent 共享相同的主键

    jakarta-ee - 如何将 JPA 和 JTA 与事务管理器一起使用?

    java - 与 Eclipselink DescriptorCustomizer 的软删除级联

    java - Persistence.xml 是可选的吗?