Apache---Ant工具簡單使用
Apache Ant,是一個將軟體編譯、測試、部署等步驟聯絡在一起加以自動化的一個工具,大多用於Java環境中的軟體開發。由Apache軟體基金會所提供。
常用標籤
1.<project>標籤
每個構建檔案對應一個專案。<project>標籤是構建檔案的根標籤。它可以有多個內在屬性, 就如程式碼中所示,其各個屬性的含義分別如下。
(1) default表示預設的執行目標,即指定預設的target(即任務)。這個屬性是必須的。
(2) basedir表示專案的基準目錄。
(3) name表示專案名。
(4) description表示專案的描述。
每個構建檔案都對應於一個專案,但是大型專案經常包含大量的子專案,每一個子專案都可以有
自己的構建檔案。
2.<target>標籤
一個專案標籤下可以有一個或多個target標籤。一個target標籤可以依賴其他的target標籤。例 如,有一個target用於編譯程式,另一個target用於生成可執行檔案。在生成可執行檔案之前必須先編譯該檔案,因此可執行檔案的target依賴於編譯程式的target。Target的所有屬性如下。
(1).name表示目標名,這個屬性是必須的。
(2).depends表示依賴的目標。
(3)if表示僅當屬性設定時才執行。
(4)unless表示當屬性沒有設定時才執行。
(5)description表示專案的描述。
Ant的depends屬性指定了target的執行順序。Ant會依照depends屬性中target出現順序依次執行 每個target。在執行之前,首先需要執行它所依賴的target。程式中的名為run的target的 depends屬性compile,而名為compile的target的depends屬性是prepare,所以這幾個target執 行的順序是prepare->compile->run。一個target只能被執行一次,即使有多個target依賴於它。如果沒有if或unless屬性target總 會被執行。
3.<mkdir>標籤
該標籤用於建立一個目錄,它有一個屬性dir用來指定所建立的目錄名,其屬性如下:
(1) dir:要建立的目錄。可以是絕對路徑,還是可以是相對於project的basedir的相對路徑。
其程式碼如下:
<mkdir dir=”${class.root}”/>
4<jar>標籤
該標籤用來生成一個JAR檔案,其屬性如下。
(1) destfile表示JAR檔名。
(2) basedir表示被歸檔的檔名。
(3) includes表示被歸檔的檔案模式。
(4) excludes表示被排除的檔案模式。
5.<javac標籤>
該標籤用於編譯一個或一組java檔案,其屬性如下。
(1).srcdir表示源程式的目錄。
(2).destdir表示class檔案的輸出目錄。
(3).include表示被編譯的檔案的模式。
(4).excludes表示被排除的檔案的模式。
(5).classpath表示所使用的類路徑。
(6).debug表示包含的除錯資訊。
(7).optimize表示是否使用優化。
(8).verbose 表示提供詳細的輸出資訊。
(9).fileonerror表示當碰到錯誤就自動停止。
6.<java>標籤
該標籤用來執行編譯生成的.class檔案,其屬性如下。
(1).classname 表示將執行的類名。
(2).jar表示包含該類的JAR檔名。
(3).classpath所表示用到的類路徑。
(4).fork表示在一個新的虛擬機器中執行該類。
(5).failonerror表示當出現錯誤時自動停止。
(6).output 表示輸出檔案。
(7).append表示追加或者覆蓋預設檔案。
7.<delete>標籤
該標籤用於刪除一個檔案或一組檔案,去屬性如下。
(1)/file表示要刪除的檔案。
(2).dir表示要刪除的目錄。
(3).includeEmptyDirs 表示指定是否要刪除空目錄,預設值是刪除。
(4).failonerror 表示指定當碰到錯誤是否停止,預設值是自動停止。
(5).verbose表示指定是否列出所刪除的檔案,預設值為不列出。
8.<copy>標籤
該標籤用於檔案或檔案集的拷貝,其屬性如下。
(1).file 表示原始檔。
(2).tofile 表示目標檔案。
(3).todir 表示目標目錄。
(4).overwrite 表示指定是否覆蓋目標檔案,預設值是不覆蓋。
(5).includeEmptyDirs 表示指定是否拷貝空目錄,預設值為拷貝。
(6).failonerror 表示指定如目標沒有發現是否自動停止,預設值是停止。
(7).verbose 表示制定是否顯示詳細資訊,預設值不顯示。
Eclipse中使用Ant工具
echo標籤---類似java中 System.out.println();
<target name="dft">
<echo message="hello "></echo>
</target>
javadoc標籤---生成java文件
<target name="javaDoc" description="生成java文件">
<javadoc sourcepath="${basedir}/src"
destdir="d:/a/doc"
package="cn.hncu.*"
encoding="utf-8"
docencoding="utf-8"
charset="utf-8"
/>
</target>
jar標籤---把專案打成jar包
<target name="jar" description="打jar包">
<jar destfile="d:/a/jar/${ant.project.name}.jar" basedir="${basedir}"/>
</target>
copy標籤---進行檔案拷貝,例子:把專案部署到Tomcat中
<property name="tomcat8.5_home" value="D:\apache-tomcat-8.5.32\wtpwebapps"></property>
<target name="cp" description="拷貝專案到Tomcat工作空間">
<copy todir="${tomcat8.5_home}/${ant.project.name}" >
<fileset dir="${basedir}/WebContent">
<include name="**/*.*"/>
</fileset>
</copy>
<copy todir="${tomcat8.5_home}/${ant.project.name}/WEB-INF">
<fileset dir="${basedir}/build">
<include name="**/*.*"/>
</fileset>
</copy>
</target>
delete標籤---刪除檔案
<target name="del" description="刪除Tomcat工作空間中的當前專案">
<delete dir="${tomcat8.5_home}/${ant.project.name}">
</delete>
</target>
sql標籤---資料庫操作,例子:建立資料庫、表、初始化資料
<classpath>標籤指明資料庫驅動的jar包位置。
<!-- 定義引數 -->
<property name="driver" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://127.0.0.1:3306/mysql?useUnicode=true&characterEncoding=UTF-8"></property>
<property name="username" value="root"></property>
<property name="password" value="1234"></property>
<target name="create" description="建立資料庫和資料表">
<sql userid="${username}" url="${url}" password="${password}" driver="${driver}">
<fileset dir="${basedir}/sql/create">
<include name="**/*.sql"/>
</fileset>
<classpath>
<fileset dir="${basedir}/WebContent/WEB-INF/lib">
<include name="**/*.jar"/>
</fileset>
</classpath>
</sql>
</target>
<target name="init" description="初始化一些引數">
<sql userid="${username}" url="${url}" password="${password}" driver="${driver}">
<fileset dir="${basedir}/sql/init">
<include name="**/*.sql"/>
</fileset>
<classpath>
<fileset dir="${basedir}/WebContent/WEB-INF/lib">
<include name="**/*.jar"/>
</fileset>
</classpath>
</sql>
</target>