ant打包jar文件


        筆者之前在項目中使用的最多的打包工具要數fatjar了。打包的時候習慣於先指定可執行類,而後將全部引用的jar包以及源碼生成的class一塊兒打到 一個包裏面,運行程序的時候直接運行命令:java –jar jarname.jar。看似很方便。可是,這樣作有兩個缺點:1.將全部jar包都整合到一塊兒,致使jar包太大,通常最小几百k,最大十幾MB都有, 上傳至服務器時,耗時較長。2.每次更新jar包,引用的包又要從新打進去。其實引用的包根本就沒作更改,特別是引用的jar包較多時,打包時間較長。html

         基於上面兩個缺點,筆者開始將源程序生成的class與引用的jar包分離。即:源程序單獨打一個jar包,引用的jar包放置在統一的lib目錄。在運 行程序的時候,使用shell腳本將lib下面的jar包都加入到環境變量之中。這樣運行的較最原始使用fatjar時期稍微方便了一些:不用每次都重複 打引用的jar包,而且此時jar包變得很小,上傳很方便。但時惟一不足的地方是須要本身寫shell,將引用的jar包加入環境變量。並 且,eclipse那個導出jar包的功能用着實在不習慣。java

         參考了一些同事的作法:1.使用fatjar,classes、jars全打一塊兒。此方法果斷pass。2.使用eclipse的導出功能,導出jar包 以後。使用winrar修改jar包中的MANIFEST.MF文件,在其中加入Class-Path。此方法雖可行,但每次打包以後均需手動修改,麻煩 啊同志們。android

         最後,看了不少開源軟件均使用ant打包,因而決定嘗試一下。捉摸了一段時間,寫了個例子。放在下面,供你們參考,也爲了使本身之後回顧。shell

工程目錄結構以下圖所示:
apache

工程結構

 

工程引用了三個jar包:helloant-201111232256.jar、google-201111261330.jar、android-201111262247.jar。windows

工程只寫了一個java文件SayHello.java,其內容以下:服務器

[java] view plain copy
  1. package demo;  
  2. public class SayHello {  
  3.     public static void main(String[] args) {  
  4.         demo.HelloAnt.main(args);  
  5.         demo.Google.main(args);  
  6.         demo.Android.main(args);  
  7.     }  
  8. }  

 

main函數中的三行引用了三個jar包中的類,做用分別爲打印Hello  Ant! Hello google!以及Helloandroid!app

 

Ant對應的配置文件爲build.xml.eclipse

 

其內容以下:函數

[html] view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!--project 用於定義一個ant工程,其中的三項name、default、basedir缺一不可。  
  3. 做用分別爲:定義工程名、制定默認執行的任務、以及工程基礎的路徑型(它是計算其它路徑的基礎,通常狀況下使用.即在java工程根目錄便可)-->  
  4. <project name="sayhellousejarant" default="compile" basedir=".">  
  5.     <!--描述,我的以爲就是一提示做用,沒什麼實際用途-->  
  6.     <description>use jar test</description>  
  7.     <!--定義源文件路徑,其中的value換成location也行,使用value的時候,${src}獲得的就是src這個值,若是使用location,獲得的是src這個目錄的絕對路徑-->  
  8.     <property name="src" value="src" />  
  9.     <property name="classes" value="bin/classes" />  
  10.   
  11.     <!--構造打包時Class-Path須要的路徑 -->  
  12.     <!--pathconvert用於對目錄進行組合 property即這個組合的名字,pathsep做用是各個文件之間的分隔符,  
  13.         若是不寫,在windows平臺默認是分號。但時在MANIFEST.MF這個文件中,各個jar包之間要用空格區分,  
  14.         所以。這裏就寫成空格了  
  15.     -->  
  16.     <pathconvert property="lib" pathsep=" ">  
  17.         <!--mapper,對路徑組合方式進行控制-->  
  18.         <mapper>  
  19.             <!--chainedmapper 做用是聯合多個mapper-->  
  20.             <chainedmapper>  
  21.                 <!--過濾文件,將路徑去掉,只保留文件名-->  
  22.                 <flattenmapper />  
  23.                 <!--過濾+轉換器,將全部的文件名前面都加上一個lib,咱們知道lib目錄下面有jar包,  
  24.                     lib/*的做用實際上是將jar包名與路徑進行組合造成如:lib/google.jar這樣的相對路徑  
  25.                  -->  
  26.                 <globmapper from="*" to="lib/*" />  
  27.             </chainedmapper>  
  28.         </mapper>  
  29.         <!--按照mapper定義的格式組合lib目錄下面的全部jar文件,造成諸如lib/jar1.jar lib/jar2.jar的字符串-->  
  30.         <fileset dir="lib">  
  31.             <include name="*.jar" />  
  32.         </fileset>  
  33.     </pathconvert>  
  34.   
  35.   
  36.     <!--同lib,此處再也不解釋-->  
  37.     <pathconvert property="lib2" pathsep=" ">  
  38.         <mapper>  
  39.             <chainedmapper>  
  40.                 <flattenmapper />  
  41.                 <globmapper from="*" to="lib2/*" />  
  42.             </chainedmapper>  
  43.         </mapper>  
  44.         <fileset dir="lib2">  
  45.             <include name="*.jar" />  
  46.         </fileset>  
  47.     </pathconvert>  
  48.   
  49.     <!--單獨一個jar包,不在lib以及lib2目錄下,使用一個單獨的property定義,以便引用-->  
  50.     <property name="androidjar" value="android-201111262247.jar" />  
  51.     <!--組合各個路徑,構成MANIFEST.MF文件中Class-Path所需的字符串-->  
  52.     <property name="libs" value="${lib} ${lib2} ${androidjar}" />  
  53.   
  54.     <!--打印一下剛纔構造好的字符串,看看是否符合要求-->  
  55.     <echo>libs   ${libs}</echo>  
  56.   
  57.     <!-- 構造打包時Class-Path須要的路徑 結束-->  
  58.   
  59.     <!--建立任務init,負責初始化一些條件-->  
  60.     <target name="init">  
  61.         <!-- 建立存放編譯後的class的目錄  
  62.             mkdir能夠建立多級目錄   
  63.         -->  
  64.         <mkdir dir="${classes}" />  
  65.     </target>  
  66.   
  67.     <!--建立編譯任務,名字是compile,depends指定了comiple任務依賴init任務-->  
  68.     <target name="compile" depends="init" description="comile target">  
  69.         <!--javac,編譯,對應java中的javac命令。  
  70.         其中srcdir定義源文件路徑 destdir定義編譯後文件路徑,  
  71.         includeantruntime做用是指定編譯任務是否包含ant的classpath,無關緊要,不影響編譯,  
  72.         但不寫可能會出現警告,爲了眼不見心不煩,加上吧-->  
  73.         <javac srcdir="${src}" destdir="${classes}" includeantruntime="true">  
  74.             <!-- classpath 定義編譯須要的claspath -->  
  75.             <classpath>  
  76.                 <fileset dir="lib">  
  77.                     <include name="*.jar" />  
  78.                 </fileset>  
  79.                 <fileset dir="lib2">  
  80.                     <include name="*.jar" />  
  81.                 </fileset>  
  82.                 <fileset dir=".">  
  83.                     <include name="${androidjar}" />  
  84.                 </fileset>  
  85.             </classpath>  
  86.         </javac>  
  87.     </target>  
  88.   
  89.   
  90.     <!-- 建立時間戳 -->  
  91.     <tstamp />  
  92.   
  93.     <!--定義jarfilename,準備進行打包操做。其中ant.project.name是ant默認的一個變量,值爲最上面定義的project的name  
  94.     ${DSTAMP}爲日期,格式爲20111123;${TSTAMP}爲時間,格式爲2256,表示22點56分。  
  95.         -->  
  96.     <property name="jarfilename" value="${ant.project.name}-${DSTAMP}${TSTAMP}.jar" />  
  97.     <!--打包開始,名字爲jar,依賴任務爲compile-->  
  98.     <target name="jar" depends="compile" description="make jar file">  
  99.         <!--jar操做,jarfile指定jar包存放路徑,basedir爲編譯後的class的目錄-->  
  100.         <jar jarfile="${jarfilename}" basedir="${classes}">  
  101.             <!--爲jar包指定manifest,固然,若是jar包不須要打成runnable的形式,manifest能夠不要-->  
  102.             <manifest>  
  103.                 <!--指定main-class-->  
  104.                 <attribute name="Main-Class" value="demo.SayHello" />  
  105.                 <!--指定Class-Path-->  
  106.                 <attribute name="Class-Path" value="${libs}">  
  107.                 </attribute>  
  108.             </manifest>  
  109.         </jar>  
  110.     </target>  
  111.   
  112.     <!--運行一下jar包,試試看效果-->  
  113.     <target name="run" depends="jar">  
  114.         <!--其實這裏就是運行jar命令,注意fork必定加上,否則不起做用-->  
  115.         <java jar="${jarfilename}" fork="true">  
  116.         </java>  
  117.     </target>  
  118.   
  119.   
  120.     <!-- 清理 -->  
  121.     <target name="clean">  
  122.         <!-- 能夠以遞歸的方式刪除目錄 -->  
  123.         <delete dir="${classes}" />  
  124.         <delete dir="." includes="${ant.project.name}*.jar" />  
  125.     </target>  
  126. </project>  

 

 以後開始打包吧。

運行方式:能夠用eclipse自帶的,也可使用命令。

 

使用Eclipse自帶ant方式運行時注意選第二個ant build,在裏面選擇執行jar任務。

使用ant命令,須要先設置ant環境變量,以後在java project目錄下執行ant jar命令即可以打包了。另外還能夠運行ant、ant jar、ant run、ant clean等命令來執行編譯、打包、運行jar包、清理生存的文件等操做。

 

附Windows下設置ant環境變量的方式:

一、  設置 JAVA_HOME

二、  設置ANT_HOME 使其指向ant解壓得路徑,如c:\apache-ant-xxx

三、  在PATH中加入%ANT_HOME%/bin

四、  打開命令行,輸入ant –version看看能不能出來版本信息。能,設置好了。

相關文章
相關標籤/搜索