环境配置:weblogic 10.3 spring hibernate 3.3.0 问题描述:以上配置的项目在tomcat下运行没有问题,发布到weblogic后,启动时也是没有问题的,但不能执行数据库操作,一旦执行数据库操作,便会有异常:
Java代码 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.
例如weblogc10.3安装路径在:C:\bea\wlserver_10.3并且建立了一个base_domain的域名。
1. MyEclipse中启动做配置 在MyEclipse中启动Weblogic时可以轻易的解决这个问题:在MyEclipse的首先项中,配置服务器,打开对应的weblogic配置,展开path,在prepend一栏中,将web工程lib下的antlr_xx_xx.jar、hibernate-jpa-2.0-api-1.0.0.Final.jar、commons-lang-2.6.jar加入,点击确定,启动,ok. 2. 修改weblogic启动命令 首先说明按照这个方法做出修改后,在myeclipse中启动时是无效的,也就是这个做法不能替代1方法,当然1方法也不能替代2方法。此方法只适用于使用cmd或sh文件启动weblogic.
将antlr.jar复制到C:\bea\user_projects\domains\base_domain\lib或者C:\bea\wlserver_10.3\server\lib下。该lib目录下会有一个说明文档,大概意思是目录下的jar会被自动添加到server的启动classpath的后面,那么还需要修改startWeblogic.cmd或.sh来将antlr.jar加入到classPath的最前面。 编辑C:\bea\user_projects\domains\base_domain\bin\startWebLogic.cmd文件,在
set SAVE_JAVA_OPTIONS= 与set SAVE_CLASSPATH=之间大概在97行
后加上两行代码
set PRE_CLASSPATH=%WL_HOME%\server\lib\antlr-2.7.6.jar;%WL_HOME%\server\lib\hibernate-jpa-2.0-api-1.0.0.Final.jar;%WL_HOME%\server\lib\commons-lang.jar
set CLASSPATH=%PRE_CLASSPATH%;%SAVE_CLASSPATH%
然后保存,双击startWebLogic.cmd启动,OK