Grails 2.4.4中的Hibernate JPA冲突

时间:2014-11-18 02:46:14

标签: hibernate grails jpa datasource javassist

我一直在使用Hibernate 3将Grails 1.3.7应用程序升级到2.4.4,因为Spring Security与hibernate4插件不兼容,并且在运行时遇到了这种堆栈跟踪的问题:

java.lang.ClassCastException: com.xxxxxx.grails.domain.WorkflowStepDescription_$$_javassist_1 cannot be cast to javassist.util.proxy.ProxyObject 
at org.codehaus.groovy.grails.orm.hibernate.proxy.GroovyAwareJavassistLazyInitializer.createProxyInstance(GroovyAwareJavassistLazyInitializer.java:107)
at org.codehaus.groovy.grails.orm.hibernate.proxy.GroovyAwareJavassistLazyInitializer.getProxy(GroovyAwareJavassistLazyInitializer.java:134)
at org.codehaus.groovy.grails.orm.hibernate.proxy.GroovyAwareJavassistProxyFactory.getProxy(GroovyAwareJavassistProxyFactory.java:64) 
at org.codehaus.groovy.grails.orm.hibernate.persister.entity.GroovyAwareSingleTableEntityPersister.createProxy(GroovyAwareSingleTableEntityPersister.java:49)
at org.hibernate.event.def.DefaultLoadEventListener.createProxyIfNecessary(DefaultLoadEventListener.java:360) 
at org.hibernate.event.def.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:281) 
at org.hibernate.event.def.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:152) 
at org.hibernate.impl.SessionImpl.fireLoad(SessionImpl.java:1090) 
at org.hibernate.impl.SessionImpl.internalLoad(SessionImpl.java:1038) 
at org.hibernate.type.EntityType.resolveIdentifier(EntityType.java:630) 
at org.hibernate.type.EntityType.resolve(EntityType.java:438) 
at org.hibernate.engine.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:139) 
at org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:982) 
at org.hibernate.loader.Loader.doQuery(Loader.java:857) 
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:274) 
at org.hibernate.loader.Loader.doList(Loader.java:2542) 
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2276) 
at org.hibernate.loader.Loader.list(Loader.java:2271) 
at org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:119) 
at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1716) 
at org.hibernate.impl.CriteriaImpl.list(CriteriaImpl.java:347) 

搜索周围表明这是由于与Javassist版本的冲突,果然,我在我的内置JAR中有两个不同的版本:

hibernate-jpa-2.0-api-1.0.1.Final.jar
hibernate-jpa-2.1-api-1.0.0.Final.jar

查看grails依赖项报告,看起来对2.1的依赖性来自Grails本身:

来自Hibernate 3.6.10.18的那个:


    +--- org.grails.plugins:hibernate:3.6.10.18
    |    \--- org.hibernate:hibernate-entitymanager:3.6.10.Final
    |         \--- org.hibernate:hibernate-core:3.6.10.Final
    |              \--- org.hibernate.javax.persistence:hibernate-jpa-2.0-api:1.0.1.Final

Grails 2.4.4中的那个:


    +--- org.grails:grails-plugin-datasource:2.4.4
    |    \--- org.grails:grails-core:2.4.4
    |         \--- org.hibernate.javax.persistence:hibernate-jpa-2.1-api:1.0.0.Final

我知道Grails 2.4.4可以选择使用Hibernate 3 ...我可以通过降级数据源插件来避免这种依赖冲突吗?

1 个答案:

答案 0 :(得分:0)

好吧,这太复杂了,我怀疑它会帮助其他人,但我解决了它 - 我注意到这个例外只发生在一个特定的域类上。经过大量的反复试验后,我发现这是因为该类有一个名为" handler"的属性,我只能假设它与更高版本的javassist中的方法冲突。我将其更改为" actionHandler",错误消失了。

这两个JAR版本无疑仍然是一个问题,但在这个问题上它们是一个红色的鲱鱼。检查您的域类属性名称是否有任何可疑之处!