请參考:ant的安装与验证html
当開始一个新的项目时。首先应该编写Ant构建文件。java
构建文件定义了构建过程,并被团队开发中每个人使用。Ant构建文件默认命名为build.xml,也可以取其它的名字。apache
仅仅只是在执行的时候把这个命名看成參数传给Ant。构建文件可以放在不论什么的位置。通常作法是放在项目顶层文件夹中,这样可以保持项目的简洁和清晰。如下是一个典型的项目层次结构。
(1) src存放文件。
(2) class存放编译后的文件。app
(3) lib存放第三方JAR包。less
(4) dist存放打包,公布之后的代码。
Ant构建文件是XML文件。每个构建文件定义一个惟一的项目(Project元素)。ide
每个项目下可以定义很是多目标(target元素)。这些目标之间可以有依赖关系。当运行这类目标时,需要运行他们所依赖的目标。每个目标中可以定义多个任务,目标中还定义了所要运行的任务序列。Ant在构建目标时必须调用所定义的任务。任务定义了Ant实际运行的命令。Ant中的任务可以为3类。
(1) 核心任务。优化
核心任务是Ant自带的任务。
(2) 可选任务。ui
可选任务实来自第三方的任务。所以需要一个附加的JAR文件。
(3) 用户本身定义的任务。用户本身定义的任务有用户本身开发的任务。spa
如下我将用一个build.xml文件来讲明常见标签的使用.net
每个构建文件相应一个项目。<project>标签时构建文件的根标签。它可以有多个内在属性。就如代码中所看到的,其各个属性的含义分别例如如下。
(1) default表示默认的执行目标,这个属性是必须的。
(2) basedir表示项目的基准文件夹。
(3) name表示项目名。
(4) description表示项目的描写叙述。
每一个构建文件都相应于一个项目,但是大型项目经常包括大量的子项目,每一个子项目都可以有本身的构建文件。
演示样例:
<?xml version="1.0" encoding="gb2312" ?> <project name="test" default="jar" basedir="."> <path id="classpath"> <fileset dir="./lib" includes="*.jar"/> </path> </project>
一个项目标签下可以有一个或多个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。这里的依赖有点像java中的方法调用。请读者自行理解。
演示样例:
<target name="compile"> <mkdir dir="classes" /> </target> <target name="jar" depends="compile"> <mkdir dir="dist"/> </target>
演示样例中。名为jar的target依赖于名为compile的target。
当在命令行运行“ant jar”时。会先运行compile这个target,因而会在当前目录先生成classes目录。在生成dist目录
该标签用于建立一个文件夹,它有一个属性dir用来指定所建立的文件夹名。
使用方法见第二节
(1) destfile表示JAR文件名称。
(2) basedir表示被归档的文件名称。
(3) includes表示被归档的文件模式。
(4) exchudes表示被排除的文件模式。
演示样例:
<jar jarfile="./dist/test.jar"> <fileset dir="classes" includes="com/wk/**/*.class"> <or> <none> <filename name="com/wk/eai/cups/**/*.class"/> </none> </or> </fileset> </jar>上面的脚本表示:在dist文件夹下生成一个test.jat包。它包括的class文件来自于
com/wk/**/*.class但是会忽略
com/wk/eai/cups/**/*.class这个包下的所有class文件
(3).include表示被编译的文件的模式。
(4).excludes表示被排除的文件的模式。
(5).classpath表示所使用的类路径。
(6).debug表示包括的调试信息。
(7).optimize表示是否使用优化。
(8).verbose 表示提供具体的输出信息。
(9).fileonerror表示当碰到错误就本身主动中止。
演示样例:
<javac fork="true" executable="C:\Program Files\Java\jdk1.5.0\bin\javac" srcdir="src" destdir="classes" debug="true"> <compilerarg value="-Xlint"/> <classpath refid="classpath"/> <fileset id="src.path" dir="src"> <include name="b/*.java"/> <exclude name="b/a/*.java"/> </fileset> </javac>上面的脚本表示将src文件夹下的源文件编译成class文件到classes文件夹中。编译时用到的jar包来自于classpath所指定的文件夹。编译时的java版本号是1.5。同一时候还会将b文件夹中的java文件编译,但是会忽略b/a文件夹下的java文件,即b/a文件夹下的java文件不会被编译。
(1).classname 表示将运行的类名。
(2).jar表示包括该类的JAR文件名称。
(3).classpath所表示用到的类路径。
(4).fork表示在一个新的虚拟机中执行该类。
(5).failonerror表示当出现错误时本身主动中止。
(6).output 表示输出文件。
(7).append表示追加或者覆盖默认文件。
(3).includeEmptyDirs 表示指定是否要删除空文件夹,默认值是删除。
(4).failonerror 表示指定当碰到错误是否中止,默认值是本身主动中止。
(5).verbose表示指定是否列出所删除的文件,默认值为不列出。
演示样例:
<target name="clean" description="清除Build"> <delete dir="classes"/> <delete dir="dist" /> </target>上面的演示样例表示:运行脚本“ant clean”时,会删除classes和dist这两个目录。
通常在初始化项目时结合init使用
(4).overwrite 表示指定是否覆盖目标文件,默认值是不覆盖。
(5).includeEmptyDirs 表示制定是否拷贝空文件夹,默认值为拷贝。
(6).failonerror 表示指定如目标没有发现是否本身主动中止。默认值是中止。
(7).verbose 表示制定是否显示具体信息。默认值不显示。
演示样例:
<copy todir="classes"> <fileset dir="src"> <exclude name="**/*.java" /> <exclude name="**/.*" /> <or> <none> <filename name="com/wk/eai/ws/**/*.java"/> </none> </or> </fileset> </copy>表示将src文件夹下的文件拷贝到classes文件夹中。复制是忽略
com/wk/eai/ws/**/*.java文件夹下的java文件
如下简介构建文件里一些常用的数据类型。
(1).values 是一个命令參数。
假设參数种有空格,但又想将它做为单独一个值。则使用此属性。
(2).file表示一个參数的文件名称。在构建文件里,此文件名称相对于当前的工做文件夹。
(3).line表示用空格分隔的多个參数列表。
(4).path表示路径。
(1).file表示环境变量值得文件名称。此文件名称要被转换位一个绝对路径。
(2).path表示环境变量的路径。Ant会将它转换为一个本地约定。
(3).value 表示环境变量的一个直接变量。
(4).key 表示环境变量名。
注意 file path 或 value仅仅能取一个。
Filelist 是一个支持命名的文件列表的数据类型,包括在一个filelist类型中的文件不必定是存在的文件。下面是其所有的属性。
(1).dir是用于计算绝对文件名称的文件夹。
(2).files 是用逗号分隔的文件名称列表。
(3).refid 是对某处定义的一个<filelist>的引用。
注意 dir 和 files 都是必要的,除非指定了refid(这样的状况下,dir和files都不一样意使用)。
只是,不少ant任务构建成了隐式的fileset,这说明他们支持所有的fileset属性和嵌套元素。
下面为fileset 的属性列表。
(1).dir表示fileset 的基文件夹。
(2).casesensitive的值假设为false,那么匹配文件名称时,fileset不是区分大写和小写的,其默认值为true。
(3).defaultexcludes 用来肯定是否使用默认的排除模式,默以为true。
(4).excludes 是用逗号分隔的需要派出的文件模式列表。
(5).excludesfile 表示每行包括一个排除模式的文件的文件名称。
(6).includes 是用逗号分隔的,需要包括的文件模式列表。
(7).includesfile 表示每行包括一个包括模式的文件名称。
(3).path表示一个文件或路径名列表。
參考:
http://blog.csdn.net/witsmakemen/article/details/7929761
http://neoman.iteye.com/blog/571806