这段代码让我感到恼火,有时它会起作用,有些时候却没有!
NamedQuery :( name =“User.findByLogin”,query =“SELECT u FROM User u WHERE u.login =:login”)
public User findByLogin(String login) {
Query query = em.createNamedQuery("User.findByLogin");
query.setParameter("login", login);
try {
return (User) query.getSingleResult();
} catch (javax.persistence.NoResultException ex) {
return null;
}
}
这个错误让我发疯!
Avertissement:EJB5184:在EJB UserFacade上调用期间发生系统异常,方法:public dz.admin.entity.User dz.admin.service.UserFacade.findByLogin(java.lang.String)Avertissement:javax.ejb.EJBException .. ..引起:java.lang.ClassCastException:dz.elit.admin.entity.User无法强制转换为dz.elit.admin.service.UserFacade.findByLogin中的dz.elit.admin.entity.User(UserFacade.java: 45)
我的猜测是你有不同的类加载器。 JVM仍然认为在不同的类加载器中加载的相同类是不同的。
要验证这一点,您可以尝试捕获异常并打印/记录类加载器。
public User findByLogin(String login) {
Query query = em.createNamedQuery("User.findByLogin");
query.setParameter("login", login);
Object result = null;
try {
result = query.getSingleResult();
return (User) result ;
} catch (javax.persistence.NoResultException ex) {
return null;
} catch (ClassCastException ex) {
logger.info("Object classloader: " + result.getClass().getClassLoader());
logger.info("Target class classloader: " + User.class.getClassLoader());
if(result.getClass().getClassLoader() != User.class.getClassLoader()) {
logger.warn("Different classloaders detected!");
}
}
}
至于解决方案,当然这取决于你的其他设置......为了让你开始,我可以给你一些指向之前提出的相关问题的指示。也许那里的一些答案可能对您有所帮助:
一些建议的解决方案包括更改类加载器设置,使用通用接口或序列化/反序列化对象。
我在spring-boot应用程序中面临同样的问题,浪费了我很多时间来解决它。
由于类加载器而产生问题。
Model类和Session类的类加载器都不同。
System.out.println("ClassLoader : " + Employee.class.getClassLoader());
System.out.println(session.getClass().getClassLoader()); //Hibernate Session object
ClassLoader : org.springframework.boot.devtools.restart.classloader.RestartClassLoader@a3af3c
sun.misc.Launcher$AppClassLoader@1d16e93
我因为这种依赖性而面临这个问题。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
当我评论这个,那么我的代码工作正常,所以我建议你请检查你的罐子。
System.out.println("ClassLoader : " + Employee.class.getClassLoader());
System.out.println(session.getClass().getClassLoader()); //Hibernate Session object
ClassLoader : sun.misc.Launcher$AppClassLoader@1d16e93
sun.misc.Launcher$AppClassLoader@1d16e93
希望这个答案可以帮到你。
Query query = em.createNamedQuery("User.findByLogin");
...
return (User) query.getSingleResult();
您可能需要检查用户是否确实存在(非空)。有时它会为null,你需要重新引用它
有时它工作,有时它不工作!