【转自: http://zhucaiguai.iteye.com/blog/850394】环境配置:weblogic 10.3 spring hibernate 3.3.0
问题描述:以上配置的项目在tomcat下运行没有问题,发布到weblogic后,启动时也是没有问题的,但不能执行数据库操作,一旦执行数据库操作,便会有异常:
- org.springframework.dao.InvalidDataAccessApiUsageException: org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken
org.springframework.dao.InvalidDataAccessApiUsageException: org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken
以上问题的原因是WebLogic自身会使用Antlr去分析EJBQL,与HIBERNATE中所需要的ANTLR.JAR冲突。
解决以上问题的办法有两种(其实不止两种,这里只写出我试验成功吧,分别对应在myeclipse中启动weblogic与手工执行启动命令脚本启动weblogic),原理都是使JVM首先加载web工程中的antlr.jar,而不是weblogic自带的较低版本的jar.
1. MyEclipse中启动做配置
在MyEclipse中启动Weblogic时可以轻易的解决这个问题:在MyEclipse的首先项中,配置服务器,打开对应的weblogic配置,展开path,在prepend一栏中,将web工程lib下的antlr_xx_xx.jar加入,点击确定,启动,ok.
2. 修改weblogic启动命令
首先说明按照这个方法做出修改后,在myeclipse中启动时是无效的,也就是这个做法不能替代1方法,当然1方法也不能替代2方法。此方法只适用于使用cmd或sh文件启动weblogic.
将antlr.jar复制到domin_home/lib下。该lib目录下会有一个说明文档,大概意思是目录下的jar会被自动添加到server的启动classpath的后面,那么还需要修改startWeblogic.cmd或.sh来将antlr.jar加入到classPath的最前面。
编辑domain_home/
bin/startWebLogic.cmd文件,在
- set CLASSPATH=%SAVE_CLASSPATH%
后加上两行代码
set PRE_CLASSPATH=%DOMAIN_HOME%\lib\antlr.jar
set CLASSPATH=%PRE_CLASSPATH%;%CLASSPATH%
保存,双击startWebLogic.cmd启动,OK
================================