问题出现在CE组(他们的环境是最新的),情况是:在登陆之后就到index.jsp出现异常,然后跳转到/page/main.jsp中,就一直处于刷新状态,后台的异常是:
org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken [from com.giantstone.arch.model.ArchEtlGroup]
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
刚才解释的ClassNotFoundException:
org.hibernate.hql.ast.HqlToken发生的原因有问题,加的那行代码不是去选择ear包下边的antlr包,而是将hibernate3的查询翻译器改为hibernate2.1的。
具体原因如下:
在运行过程中出现
ClassNotFoundException:
org.hibernate.hql.ast.HqlToken 错误weblogic异常退出。
原因:
Hibernate3.0 采用新的基于ANTLR的HQL/SQL查询翻译器,在Hibernate的配置文件中,hibernate.query.factory_class属性用来选择查询翻译器。
(1)选择Hibernate3.0的查询翻译器:
hibernate.query.factory_class=
org.hibernate.hql.ast.ASTQueryTranslatorFactory
(2)选择Hibernate2.1的查询翻译器
hibernate.query.factory_class=
org.hibernate.hql.classic.ClassicQueryTranslatorFactory
为了使用3.0的批量更新和删除功能,只能选择(1)否则不能解释批量更新的语句,当使用的时候出现了不支持条件输入中文的情况。选择(2)可以支持输入中文,但没法解释批量更新语句了
在hibernate3中需要用到antlr,然而这个包在weblogic.jar中已经包含了antrl类库,就会产生一些类加载的错误,无法找到在war或者ear中的hibernate3.jar。
出现这个错误之后,antlr会调用System.exit(),这样weblogic就会中止服务。
我的解决办法:
修改% mydomain% \ startWebLogic.cmd 把 antlr-2.7.5H3.jar 放在 classpath
的最前面
例如: set
CLASSPATH=C:\bea\antlr-2.7.5H3.jar;%WEBLOGIC_CLASSPATH%;C:\bea\db2jcc.jar;C:\bea\db2jcc_license_cisuz.jar;C:\bea\jt400.jar;%POINTBASE_CLASSPATH%;%JAVA_HOME%\jre\lib\rt.jar;%WL_HOME%\server\lib\webservices.jar;%CLASSPATH%
*******************************************************************************************************************************
下面是另外一个人的解决方法
拥有Hibernate3.jar的应用,被部署到weblogic8.1上后,抛出异常 CharScanner; panic:
ClassNotFoundException: org.hibernate.hql.ast.HqlToken。
解决方法:在hibernate.properties上,或是在spring的conext xml中,加上一个属性hibernate.query.factory_class,值为org.hibernate.hql.classic.ClassicQueryTranslatorFactory。
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
总结:在新核心其他的项目组如果将环境更新到最新的环境也可能会出现这个异常,这个异常的原因就是hibernate3.0找不到antlr这个类库,而系统加载的类库可能是netware环境中的antlr类库。
归档系统中,在应用已启动的时候就用List list = sysManageService.getEtlGroupList(null);这样的HQL语句去查询数据库,但是却没有这个HqlToken这个类,因为之前加载的时候跟服务器环境中的jar包冲突了,所以就报异常了,一直启动不了,现在还要解决的是,是否其他组在没有更新其环境的情况下,利用spring 注入hibernate的hibernate.query.factory_class这个属性,会是什么情况。