一:weblogic 异常之 org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken
项目之前在 Tomcat 环境下和 webLogic 12下,运行正常, 现在换成weblogic 10部署后发现了这个报异常 org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken 异常,由于项目比较老,hibernate和mybatis结合在使用,凡是后台用到hibernate的地方都报这一个错误,几经折腾,排除了项目框架自身原因(老产品有上百家客户在使用),最后定位在weblogic版本的问题。·
Hibernate3 采用新的基于 antlr 的 HQL/SQL 查询翻译器,在 hibernate3 中需要用到 antlr,然而这个包在 weblogic 中已经包含了 antrl 类库,所以会产生一些类加载的错误,无法找到在 war 或 ear 中的 hibernate3.jar。
解决方案
方案一:修改 Hibernate 配置 hibernate.query.factory_class 设置其他查询翻译器
(1)使用 Hibernate3 的查询翻译器:
hibernate.query.factory_class= org.hibernate.hql.ast.ASTQueryTranslatorFactory
(2)使用 Hibernate2 的查询翻译器:
hibernate.query.factory_class= org.hibernate.hql.classic.ClassicQueryTranslatorFactory
说明:为了使用 Hibernate3 的批量更新和删除功能,只能选择(1),否则不能解释批量更新的语句,但使用(1)时查询条件不支持中文。如果使用(2),可以支持中文,但没法解释批量更新语句了
方案二:修改 weblogic 的类加载顺序
在项目的 WEB-INF 目录下新建 weblogic.xml,然后将 <prefer-web-inf-classes> 的值设为 true。
<weblogic-web-app
xmlns="http://xmlns.oracle.com/weblogic/weblogic-web-app"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.oracle.com/weblogic/weblogic-web-app
http://xmlns.oracle.com/weblogic/weblogic-web-app/1.3/weblogic-web-app.xsd">
<container-descriptor>
<!--优先加载位于 Web 应用程序的 WEB-INF 目录中的类,然后再加载应用程序或系统类加载器中的类-->
<prefer-web-inf-classes>false</prefer-web-inf-classes>
</container-descriptor>
</weblogic-web-app>
方案三:设置 weblogic 的 PRE_CLASSPATH(重新指定一个项目中使用的antlr版本)
方案四:设置 prefer-application-resources 和 prefer-application-packages
修改 WEB-INF/weblogic.xml
<weblogic-web-app
xmlns="http://xmlns.oracle.com/weblogic/weblogic-web-app"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.oracle.com/weblogic/weblogic-web-app
http://xmlns.oracle.com/weblogic/weblogic-web-app/1.3/weblogic-web-app.xsd">
<container-descriptor>
<prefer-web-inf-classes>false</prefer-web-inf-classes>
<prefer-application-resources>
<resource-name>META-INF/services/javax.xml.ws.spi.Provider</resource-name>
</prefer-application-resources>
<prefer-application-packages>
<package-name>antlr.*</package-name>
</prefer-application-packages>
</container-descriptor>
</weblogic-web-app>
二:weblogic异常之 java.lang.NoSuchMethodError:org.apache.commons.lang.time.DateUtils.addDays
项目之前在 Tomcat 环境下和 webLogic 12下,运行正常, 现在换成weblogic 10部署后发现了这个报异常 java.lang.NoSuchMethodError: org.apache.commons.lang.time.DateUtils.addDays异常,几经折腾,排除了项目框架自身原因(老产品有上百家客户在使用),最后定位也在weblogic版本的问题。·
解决方案
将common.lang.xxx的jar包(对应你项目中实际使用的jar包) 改为weblogic module下面的com.bea.core.apache.commons.lang_2.1.0.jar名字。然后上传weblogic module对应的目录 替换即可
迁移环境到weblogic下,应该还有很多坑,欢迎分享!