公司开发项目一直用tomcat,最近把项目部署到weblogic下用eclipse打印日志报错:
org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'formDataDao' defined in file [F:\workSpace\iaf-workflow\bin\com\iss\workflow\support\businesssample\mywork\dao\FormDataDaoImpl.class]: Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'workflow.transactionInterceptor' defined in file [F:\workSpace\workflow\bin\spring-workflow-db.xml]: Cannot resolve reference to bean 'workflow.transactionManager' while setting bean property 'transactionManager'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'workflow.transactionManager' defined in file [F:\workSpace\workflow\bin\spring-workflow-db.xml]: Cannot resolve reference to bean 'sessionFactory' while setting bean property 'sessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in file [F:\workSpace\iaf-workflow\bin\spring-workflow-context.xml]: Invocation of init method failed; nested exception is org.hibernate.HibernateException: Errors in named queries: findTasks, findMessages, findTimers, findGroupsByUserAndGroupType, findProcessInstanceIds, findJobsWithException, findProcessInstanceById, findExecutionById, findProcessInstanceByIdIgnoreSuspended, findGroupsByUser, findFirstDueJob, findExclusiveJobs, findFirstAcquirableJob
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:527)
错误日志太多,不再多拷贝了。
问题原因:
Hibernate3 采用新的基于 antlr 的 HQL/SQL 查询翻译器,在 hibernate3 中需要用到 antlr,然而这个包在 weblogic 中已经包含了 antrl 类库,所以会产生一些类加载的错误,无法找到在 war 或 ear 中的 hibernate3.jar。
解决方案:
第一步:
将antlr-2.7.7.jar(版本根据自己项目中用到的)包拷贝至 C:\Oracle\Middleware\wlserver_10.3\server\lib(weblogic默认安装C盘)目录下,修改域C:\Oracle\Middleware\user_projects\domains\base_domain\bin下的setDomainEnv.cmd ,在set JAVA_HOME=%JAVA_HOME%下加上一行set PRE_CLASSPATH=%WL_HOME%\server\lib\antlr-2.7.7.jar
第二步:
在应用的webapp/WEB-INF目录下新建weblogic.xml文件,内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<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-packages>
<package-name>antlr.*</package-name>
</prefer-application-packages>
<prefer-application-resources>
<resource-name>META-INF/services/javax.xml.ws.spi.Provider</resource-name>
</prefer-application-resources>
</container-descriptor>
</weblogic-web-app>
重新部署,问题解决,感谢前人的总结。
参考博客http://blog.csdn.net/hemingwang0902/article/details/42913809