在webLogic 10.3中部署Hibernate 3.5出現 ClassNotFoundException解決辦法

在開發Hibernate的Web項目應用時使用tomcat時運行很好,但實際生產環境中要部署到WebLogic就會出現一些ClassNotFoundException異常。

org.hibernate.QueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken異常
這是使用Hibernate 3.0以後版本均會出現的異常;

exception is java.lang.NoSuchMethodError: javax.persistence.UniqueConstraint.name()Ljava/lang/String,如果使用Hibernate 3.5,在實體中使用了唯一約束會出現這個異常,因爲在Hibernate 3.5使用了最新的Jpa 2.0,WebLogic中還是Jpa 1.0, UniqueConstraint.name在Jpa 2.0纔有。

exception is java.lang.NoSuchMethodError: org.apache.commons.lang.ArrayUtils.isNotEmpty,我在項目使用了比較新版本的commons-lang-2.5.jar在webLogic 10.3會報這個異常;

在網search一下,解決ClassNotFoundException異常最常用的辦法就是將出現異常類所在的jar包入到weblogic環境中的classpath最前面加載,將相應的antlr-2.7.6.jar、hibernate-jpa-2.0-api-1.0.0.Final.jar、commons-lang-2.5.jar copy到${WL_HOME/}server/lib/或其他目錄,可以修改${DOMAIN_HOME}/bin/startWebLogic.sh,在CLASSPATH之前加上下面一句:
Java代碼  收藏代碼
  1. 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-2.5.jar”  

並將修改爲CLASSPATH="${SAVE_CLASSPATH}"
Java代碼  收藏代碼
  1. CLASSPATH="${PRE_CLASSPATH}:${SAVE_CLASSPATH}"  


或者修改${DOMAIN_HOME}/bin/setDomainEnv.sh,在setDomainEnv.sh前面加入一句:
Java代碼  收藏代碼
  1. EXT_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-2.5.jar”  
  2. export EXT_PRE_CLASSPATH  


在我項目實踐中發現加入antlr-2.7.6.jar、hibernate-jpa-2.0-api-1.0.0.Final.jar、commons-lang-2.5.jar後,前兩個起作用,異常消除,commons-lang-2.5.jar沒有作用,exception is java.lang.NoSuchMethodError: org.apache.commons.lang.ArrayUtils.isNotEmpty異常依舊,當時沒有解決方法,只好在項目中去掉ArrayUtils.isNotEmpty,杯具!!!

後來在網上找到一種更有效解決ClassNotFoundException的,可以解決所有WebLogic中的ClassNotFoundException。改解決辦法是將web項目包含進ear包中。將web項目打包成war文件,在war文件相同目錄下建立META-INF目錄,目錄建立application.xml、weblogic-application.xml兩個文件,文件內容很簡單,開發過weblogic EJB應用的應該很清楚。
application.xml
Java代碼  收藏代碼
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE application PUBLIC '-//Sun Microsystems, Inc.//DTD J2EE Application 1.3//EN' 'http://java.sun.com/dtd/application_1_3.dtd'>  
  3. <application>  
  4.   <display-name>cckzzx</display-name>  
  5.   <description>cckzzx</description>  
  6.   <module>  
  7.     <web>  
  8.       <web-uri>cckzzx.war</web-uri>  
  9.       <context-root>cckzzx</context-root>  
  10.     </web>  
  11.   </module>  
  12. </application>  


weblogic-application.xml
Java代碼  收藏代碼
  1. <?xml version="1.0"?>  
  2. <weblogic-application xmlns="http://www.bea.com/ns/weblogic/90"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">  
  4.     <application-param>  
  5.         <param-name>webapp.encoding.default</param-name>  
  6.         <param-value>UTF-8</param-value>  
  7.     </application-param>  
  8.     <prefer-application-packages>  
  9.         <package-name>org.apache.commons.*</package-name>     
  10.         <package-name>antlr.*</package-name>  
  11.         <package-name>javax.persistence.*</package-name>  
  12.     </prefer-application-packages>  
  13. </weblogic-application>  

<prefer-application-packages>
表示在weblogic中優先使用當前應用中的jar包
最後將war文件和META-INF目錄打包成ear包、部署。在這裏我參考網上資料寫了一個ant腳本build.xml對項目進行ear打包
build.xml
Java代碼  收藏代碼
  1. <?xml version="1.0"?>  
  2. <project name="cckzzx" default="ear" basedir=".">  
  3.     <property name="project.name" value="cckzzx" />  
  4.     <property name="app.dir" value="${basedir}" />  
  5.     <property name="src.java.dir" value="${app.dir}/src/main/java" />  
  6.     <property name="src.resources.dir" value="${app.dir}/src/main/resources" />  
  7.     <property name="weblogic.home" value="/opt/Oracle/Middleware/wlserver_10.3" />  
  8.     <property name="wls.username" value="weblogic" />  
  9.     <property name="wls.password" value="weblogic123" />  
  10.     <property name="wls.hostname" value="localhost" />  
  11.     <property name="wls.port" value="7001" />  
  12.     <property name="wls.server.name" value="AdminServer" />  
  13.     <property name="build.dir" value="${app.dir}/build" />  
  14.     <property name="build.classes.dir" value="${build.dir}/classes" />  
  15.     <property name="build.tmp.dir" value="${build.dir}/tmp" />  
  16.     <path id="build.classpath" description="編譯時的classpath路徑">  
  17.         <fileset dir="${basedir}/WebRoot/WEB-INF/lib">  
  18.   
  19.         <include name="*.jar" />  
  20.         </fileset>  
  21.         <fileset dir="${weblogic.home}/server/lib">  
  22. <include name="weblogic.jar" />  
  23.         </fileset>  
  24.         <pathelement location="${build.classes.dir}" />  
  25.     </path>  
  26.     <taskdef name="wldeploy" classname="weblogic.ant.taskdefs.management.WLDeploy" classpathref="build.classpath" />  
  27.     <target name="clean" description="刪除編譯目錄">  
  28.         <delete dir="${build.dir}" />  
  29.     </target>  
  30.     <target name="prepare" depends="clean" description="創建編譯目錄">  
  31.         <mkdir dir="${build.dir}" />  
  32.         <mkdir dir="${build.classes.dir}" />  
  33.         <mkdir dir="${build.tmp.dir}" />  
  34.     </target>  
  35.     <target name="compile" depends="prepare" description="編譯">  
  36. <javac srcdir="${src.java.dir}" destdir="${build.classes.dir}" compiler="org.eclipse.jdt.core.JDTCompilerAdapter" encoding="UTF-8" source="1.6" target="1.6" debug="on" deprecation="on" optimize="off" includes="**">  
  37.     <classpath refid="build.classpath" />  
  38.     </javac>  
  39.     </target>  
  40.     <target name="ear" depends="compile" description="打包EAR包">  
  41.     <jar jarfile="${build.dir}/${project.name}.jar">  
  42.     <fileset dir="${build.classes.dir}">  
  43.     <include name="com/**/*.class" />  
  44.     <include name="**/*.xml" />  
  45.     </fileset>  
  46.     </jar>  
  47.     <mkdir dir="${build.tmp.dir}/WebRoot" />  
  48.     <copy todir="${build.tmp.dir}/WebRoot">  
  49.     <fileset dir="${app.dir}/WebRoot">  
  50.     <exclude name="WEB-INF/classes/**" />  
  51.     </fileset>  
  52.     </copy>  
  53.     <copy todir="${build.tmp.dir}/WebRoot/WEB-INF/lib">  
  54.     <fileset file="${build.dir}/${project.name}.jar" />  
  55.     </copy>  
  56.     <mkdir dir="${build.tmp.dir}/WebRoot/WEB-INF/classes" />  
  57.     <copy todir="${build.tmp.dir}/WebRoot/WEB-INF/classes">  
  58.     <fileset dir="${src.resources.dir}" />  
  59.     </copy>  
  60.     <war warfile="${build.dir}/${project.name}.war" webxml="${build.tmp.dir}/WebRoot/WEB-INF/web.xml">  
  61.     <fileset dir="${build.tmp.dir}/WebRoot">  
  62.     <exclude name="WEB-INF/web.xml" />  
  63.     </fileset>  
  64.     </war>  
  65.     <ear earfile="${build.dir}/${project.name}.ear" appxml="${app.dir}/src/weblogic/META-INF/application.xml">  
  66.             <fileset dir="${app.dir}/src/weblogic">  
  67.                 <include name="META-INF/weblogic-application.xml" />  
  68.     </fileset>  
  69.     <fileset dir="${build.dir}">  
  70.     <include name="${project.name}.war" />  
  71.     </fileset>  
  72.     </ear>  
  73.   
  74.     <delete file="${build.dir}/${project.name}.jar" />  
  75.     <delete file="${build.dir}/${project.name}.war" />  
  76.     <delete dir="${build.classes.dir}" />  
  77.     <delete dir="${build.tmp.dir}" />  
  78.     </target>  
  79.   
  80.     <target name="deploy" depends="ear,undeploy" description="佈署EAR服務">  
  81.         <wldeploy action="deploy" name="${project.name}" source="${build.dir}/${project.name}.ear" targets="${wls.server.name}" user="${wls.username}" password="${wls.password}" adminurl="t3://${wls.hostname}:${wls.port}" debug="true" verbose="true" failοnerrοr="true" />  
  82.     <echo message="come here......" />    <echo message="deploy success......." />  
  83.     </target>  
  84.     <target name="undeploy" description="刪除EAR服務">  
  85.     <wldeploy action="undeploy" name="${project.name}" targets="${wls.server.name}" user="${wls.username}" password="${wls.password}" adminurl="t3://${wls.hostname}:${wls.port}" debug="false" verbose="false" failοnerrοr="false" />  
  86.     </target>  
  87. </project>  


如果項目中使用了泛型,使用該腳本如果拋出無法確定 T 的類型參數;對於上限爲 T ,java.lang.Object 的類型變量 T,不存在唯一最大實例異常,在eclipse中可以編譯運行,爲什麼用ant就不行了呢?
解決方法是在classpath加入${eclipse_home}/plugins/org.eclipse.jdt.core_3.6.1.v_A68_R36x.jar和從org.eclipse.jdt.core_3.6.1.v_A68_R36x.jar解決出來的jdtCompilerAdapter.jar兩個包。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章