javax

javax.persistence.OneToMany.orphanRemoval()Z异常 排查方法及解决办法

问题描述:

工作中某个项目是一个比较旧的项目(基于S2SH的),没有单元测试类。开发过程里面很不方便。因此,决定给开发的同事写一个单元测试的示例(同事都比较年年轻,不愿意写单元测试),这样可以让后面的同事参考编写单元测试类,方便开发过程里面进行调试或排查问题。

使用junit编写好单元测试类后,,运行时老报错:
java.lang.IllegalStateException: Failed to load ApplactionContext …
… Caused by: java.lang.NoSuchMethodError: javax.persistence.OneToMany.orphanRemoval()Z …

但项目在本地tomcat可以正常运行。仔细检查单元测试类中引用的配置文件,连接数据库配置,都是正确的,因此觉得很奇怪。

网上搜索资料说hibernate-jpa-2.0-api-1.0.0.Final和ejb3-persistence有冲突,要把ejb3-persistence干掉。(见解决javax.persistence.OneToMany.orphanRemoval()Z异常办法)

项目中与hibernate相关的jar包有2个:
hibernate3.jar
hibernate-jpa-2.0-api-1.0.1.Final.jar

但没有ejb3-persistence jar包。

后面继续搜索资料,找到这哥们写的排查方法,可以打印出现问题的类jar路径信息参考:

System.out.println(Class.forName( “javax.persistence.OneToMany” ).getProtectionDomain().getCodeSource().getLocation().getFile());

按照上述方法,输出加载的jar路径,果然是这样,我输出的jar为:
/D:/**********/lib/persistence-api-1.0.jar

就是这个jar包搞的鬼,把这个jar包从/lib/目录移掉后,再运行单元测试类 就正常启动了。

你可能感兴趣的:(J2EE,Hibernate)