奇怪的classCastException hibernate 3.5 glassfish

use*_*217 6 java hibernate jpa glassfish classcastexception

嗨,我有一个问题,我无法自己解决.我有一个war文件打包在耳中并运行在glassfish 3.0.1上,hibernate 3.5作为JPA提供程序.我用maven编译它并用想法或手动部署它.每隔一次我在我的DAO中得到一个强制转换异常:

java.lang.ClassCastException: com.myproject.domain.entity.User cannot be cast to 
com.myproject.domain.entity.User
Run Code Online (Sandbox Code Playgroud)

其他时候它完美无缺.这种行为没有模式.有人可以对这里发生的事情有所了解吗?

在com.myproject.domain.dao.UserDAOImpl.checkUserSessionValid(UserDAOImpl.java:195)中抛出异常的示例方法

public User checkUserSessionValid(String sessionId) {
        User user = null;
        EntityManager em = provider.entityManager();

        try {
            em.getTransaction().begin();
           //Query q = em.createQuery("SELECT u FROM User u WHERE u.session.sessionId = :sessionId"); makes no difference :/
            Query q = em.createQuery("SELECT u FROM User u WHERE u.session.sessionId = :sessionId",User.class);
            q.setParameter("sessionId", sessionId);
            user = (User) q.getSingleResult();

            em.getTransaction().commit();
        } catch (NoResultException ignored) {

        } finally {
            em.close();
        }

        return user;
 }

My libraries
[INFO] +- org.apache.geronimo.specs:geronimo-jpa_2.0_spec:jar:1.0:provided
[INFO] +- javax.validation:validation-api:jar:1.0.0.GA:compile
[INFO] +- org.hibernate:hibernate-annotations:jar:3.5.1-Final:compile
[INFO] |  +- org.hibernate:hibernate-core:jar:3.5.1-Final:compile
[INFO] |  |  +- antlr:antlr:jar:2.7.6:compile
[INFO] |  |  +- commons-collections:commons-collections:jar:3.2.1:compile
[INFO] |  |  +- dom4j:dom4j:jar:1.6.1:compile
[INFO] |  |  |  \- xml-apis:xml-apis:jar:1.0.b2:compile
[INFO] |  |  \- javax.transaction:jta:jar:1.1:provided (scope managed from compile)
[INFO] |  +- org.hibernate:hibernate-commons-annotations:jar:3.2.0.Final:compile
[INFO] |  +- org.hibernate.javax.persistence:hibernate-jpa-2.0-api:jar:1.0.0.Final:compile
[INFO] |  \- org.slf4j:slf4j-api:jar:1.5.2:compile
[INFO] +- org.hibernate:hibernate-entitymanager:jar:3.5.1-Final:compile
[INFO] |  +- cglib:cglib:jar:2.2:compile
[INFO] |  |  \- asm:asm:jar:3.1:compile
[INFO] |  \- javassist:javassist:jar:3.9.0.GA:compile
[INFO] +- org.hibernate:hibernate-validator:jar:4.1.0.Final:compile
[INFO] +- org.slf4j:slf4j-simple:jar:1.5.2:test
[INFO] +- mysql:mysql-connector-java:jar:5.1.13:test
[INFO] +- org.hsqldb:hsqldb:jar:2.0.0:test
Run Code Online (Sandbox Code Playgroud)

Tho*_*mas 3

嗯,我们有时在使用 JBoss 时也会遇到类似的错误。问题是类加载器(类加载器存储库)问题。当多个类加载器加载同一个类时,您可能会遇到该异常,因为加载器 1 加载的类和加载器 2 加载的类不同。

在我们的例子中,我们能够通过启用按值传递语义来解决这个问题,即每当跨越某些类加载器(或应用程序)边界时,值就会被序列化/反序列化。也许您也可以检查 Glassfish(并查找如何在那里完成类加载)。

您还可以检查类路径中是否有库的多个副本或版本。