2

有人可以帮我调查一下吗,可能发生了什么导致此应用程序生成此错误。我正在关注在 Netbeans 中使用 Hibernate 的本教程。到达“from Film”这一行后,根据教程执行测试以读取 Film 表的记录,但结果是以下错误。我用谷歌搜索要做什么,到目前为止我所看到的只是据报道 javassist jar 文件可能存在于不同的目录中。一个,在 Hibernate (Hibernate 4.x-javassist-3.15.0.GA) 目录中,我发现这是真的,另一个在 glassfish (Glassfish Server 4) 目录中。我尝试在 glassfish lib 目录中搜索它,似乎不存在这样的东西。

java.lang.ClassCastException: dvdstore.Language_$$_javassist_4 cannot be cast to javassist.util.proxy.ProxyObject
    at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.getProxy(JavassistLazyInitializer.java:147)
    at org.hibernate.proxy.pojo.javassist.JavassistProxyFactory.getProxy(JavassistProxyFactory.java:71)
    at org.hibernate.tuple.entity.AbstractEntityTuplizer.createProxy(AbstractEntityTuplizer.java:631)
    at org.hibernate.persister.entity.AbstractEntityPersister.createProxy(AbstractEntityPersister.java:3737)
    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.hql.classic.QueryTranslatorImpl.list(QueryTranslatorImpl.java:940)
    at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:196)
    at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1268)
    at org.hibernate.impl.QueryImpl.list(QueryImpl.java:102)

项目的 jar 列表。 项目的jar文件列表 在此处输入图像描述

4

1 回答 1

3

您使用的 javassist 版本太旧。对于 Hibernate 4,您需要一个比 3.16 更新的 javassist 版本。在这个相关问题中讨论了同样的问题。考虑使用 Maven 或 Gradle 等构建工具来构建您的项目。这些工具会为您解决传递依赖关系,这样您就可以避免此类版本冲突。

于 2014-04-24T10:19:19.817 回答