初识Ant
Apache Ant,是一个将软件编译、测试、部署等步骤联系在一起加以自动化的一个工具,大多用于Java环境中的软件开发。
Ant的原名为Another neat tool,翻译过来为另外一个干净的工具,在Java程序的开发中,ant是一个极好的助手。Ant使用XML格式的文件作为其运行的脚本,xml已经被 大多数组织承认为通用的数据交换协议,具有容易阅读,编写,修改等良好的特性,被大多数人所接受。Ant运行的XML脚本文件中的每个元素都代表一个动 作,ant通过动作调用相应的程序来执行任务,完成用户的操作。执行命令是ant的基本目标,把完成一项任务所需的命令按照正常的顺序写入ant脚本文 件,ant调用脚本顺序执行,便可以完成一项大的任务。脚本具有一次完成编写,多次使用的特性,适合可重复的,顺序完成的任务。
默认情况下,XML文件名为bild.xml 。
构建ant环境
要使用ant首先要构建一个ant环境,步骤很简单:
1),安装jdk,设置JAVA_HOME ,PATH ,CLASS_PATH
2),下载ant 地址www.apache.org
3), 解压ant 你得到的是一个压缩包,解压缩它,并把它放在一个尽量简单的目录
4), 设置ANT_HOME PATH中添加ANT_HOME目录下的bin目录
5),测试一下你的设置,开始–>运行–>cmd进入命令行–>键入 ant 回车,如果看到
Buildfile: build.xml does not exist!
Build failed
那么恭喜你你已经完成ant的设置
使用Ant
<?xml version=”1.0″ encoding=”UTF-8″?>
<project name=”HelloWorld” default=”run” basedir=”./”>
<property name=”src” value=”src” />
<property name=”build.dir” value=”build” />
<property name=”build.classes” value=”${build.dir}/classes” />
<property name=”build.lib” value=”${build.dir}/lib” />
<property name=”hello_jar” value=”${build.lib}/hello1.jar” />
<target name=”init”>
<mkdir dir=”${build.dir}” />
<mkdir dir=”${build.lib}” />
<mkdir dir=”${build.classes}” />
</target>
<target name=”compile” depends=”init”>
<javac srcdir=”${src}” destdir=”${build.classes}” />
</target>
<target name=”build” depends=”compile”>
<jar jarfile=”${hello_jar}” basedir=”${build.classes}” />
</target>
<target name=”run” depends=”build”>
<java classname=”com.javachen.ant.HelloWorld” classpath=”${build.classes}” />
</target>
<target name=”clean”>
<delete dir=”${build.dir}” />
<delete file=”${hello_jar}” />
</target>
<target name=”rerun” depends=”run,clean”>
<ant target=”clean” />
<ant target=”run” />
</target>
</project>
<project name=”HelloWorld” default=”run” basedir=”.”>
</project>
分析说明:
ant 的所有内容必须包含在这个里边,name是你给它取的名 字,basedir故名思意就是工作的根目录 .代表当前目录。default代表默认要做的事情。
特性定义允许我们避免在构建文件中将目录名硬编码。这些路径通常都是相对于<project> 元素所指定的基目录。
例如,以下标签设置了源文件目录名。
<property name=”src” value=”src”/>
类似程序中的变量,为什么这么做想一下变量的作用
其后,这个构建文件定义了多个目标。每个目标都有一个名字,如“prepare”、“clean”或“compile”。开发人员从命令行调用 Ant 时要结合这些目标名。每个目标定义了0 个或多个依赖关系(d e p e n d e n c y ), 同时还有一个可选的description 属性(attribute)。依赖关系指定了在当前目标执行之前,Ant 必须先执行的目标。例如“prepare”必须在“compile”之前执行。对于Ant 将显示的目标,description 属性为其提供一个适合阅读的描述。
把你想做的每一件事情写成一个target ,它有一个名字,depends是它所依赖的target,在执行这个target 例如这里的compile之前ant会先检查init是否曾经被执行过,如果执行过则直接直接执行compile,如果没有则会先执行它依赖的 target例如这里的init,然后在执行这个target。
如我们的计划
编译:
<target name=”compile” depends=”init”>
<javac srcdir=”${src}” destdir=”${build.classes}” />
</target>
做jar包:
<target name=”build” depends=”compile”>
<jar jarfile=”${hello_jar}” basedir=”${build.classes}” />
</target>
运行:
<target name=”run” depends=”build”>
<java classname=”com.javachen.ant.HelloWorld” classpath=”${build.classes}” />
</target>
为了不用拷贝,我们可以在最开始定义好目标文件夹,这样ant直接把结果就放在目标文件夹中了.
新建文件夹:
<target name=”init”>
<mkdir dir=”${build.dir}” />
<mkdir dir=”${build.lib}” />
<mkdir dir=”${build.classes}” />
</target>
为了更多一点的功能体现,又加入了两个target:
删除生成的文件
<target name=”clean”>
<delete dir=”${build.dir}” />
<delete file=”${hello_jar}” />
</target>
再次运行,这里显示了如何在一个target里边调用其他的 target
<target name=”rerun” depends=”clean,run”>
<ant target=”clean” />
<ant target=”run” />
</target>
Ant build.xml配置文件解释
<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总会被执 行。
<mkdir>标签
该标签用于创建一个目录,它有一个属性dir用来指定所创建的目录名,其代码如下:
<mkdir dir=”${class.root}”/>
通过以上代码就创建了一个目录,这个目录已经被前面的property标签所指定。
<jar>标签
该标签用来生成一个JAR文件,其属性如下。
(1) destfile表示JAR文件名。
(2) basedir表示被归档的文件名。
(3) includes表示别归档的文件模式。
(4) exchudes表示被排除的文件模式。
<javac标签>
该标签用于编译一个或一组java文件,其属性如下。
(1).srcdir表示源程序的目录。
(2).destdir表示class文件的输出目录。
(3).include表示被编译的文件的模式。
(4).excludes表示被排除的文件的模式。
(5).classpath表示所使用的类路径。
(6).debug表示包含的调试信息。
(7).optimize表示是否使用优化。
(8).verbose 表示提供详细的输出信息。
(9).fileonerror表示当碰到错误就自动停止。
<java>标签
该标签用来执行编译生成的.class文件,其属性如下。
(1).classname 表示将执行的类名。
(2).jar表示包含该类的JAR文件名。
(3).classpath所表示用到的类路径。
(4).fork表示在一个新的虚拟机中运行该类。
(5).failonerror表示当出现错误时自动停止。
(6).output 表示输出文件。
(7).append表示追加或者覆盖默认文件。
<delete>标签
该标签用于删除一个文件或一组文件,去属性如下。
(1)/file表示要删除的文件。
(2).dir表示要删除的目录。
(3).includeEmptyDirs 表示指定是否要删除空目录,默认值是删除。
(4).failonerror 表示指定当碰到错误是否停止,默认值是自动停止。
(5).verbose表示指定是否列出所删除的文件,默认值为不列出。
<copy>标签
该标签用于文件或文件集的拷贝,其属性如下。
(1).file 表示源文件。
(2).tofile 表示目标文件。
(3).todir 表示目标目录。
(4).overwrite 表示指定是否覆盖目标文件,默认值是不覆盖。
(5).includeEmptyDirs 表示制定是否拷贝空目录,默认值为拷贝。
(6).failonerror 表示指定如目标没有发现是否自动停止,默认值是停止。
(7).verbose 表示制定是否显示详细信息,默认值不显示。
Ant的数据类型
在构建文件中为了标识文件 或文件组,经常需要使用数据类型。数据类型包含在 org.apache.tool.ant.types包中。下面镜简单介绍构建文件中一些常用的数据类型。
1. argument 类型
由Ant构建文件调用的程序,可以通过<arg>元素向其传递命令行参数,如 apply,exec和java任务均可接受嵌套<arg>元素,可以为各自的过程调用指定参数。以下 是<arg>的所有属性。
(1).values 是一个命令参数。如果参数种有空格,但又想将它作为单独一个值,则使用此属性。
(2).file表示一个参数的文件名。在构建文件中,此文件名相对于当前的工作目录。
(3).line表示用空格分隔的多个参数列表。
(4).path表示路径。
2.ervironment 类型
由Ant构建文件调用的外部命令或程序,<env>元素制定了哪些环境变量 要传递给正在执行的系统命令,<env>元素可以接受以下属性。
(1).file表示环境变量值得文件名。此文件名要被转换位一个绝对路径。
(2).path表示环境变量的路径。Ant会将它转换为一个本地约定。
(3).value 表示环境变量的一个直接变量。
(4).key 表示环境变量名。
注意 file path 或 value只能取一个。
3.filelist类型
Filelist 是一个支持命名的文件列表的数据类型,包含在一个filelist类型中的文件不一定是存在的文件。以下 是其所有的属性。
(1).dir是用于计算绝对文件名的目录。
(2).files 是用逗号分隔的文件名列表。
(3).refid 是对某处定义的一个<filelist>的引用。
注意 dir 和 files 都是必要的,除非指定了refid(这种情况下,dir和files都不允许使用)。
4.fileset类型
Fileset 数据类型定义了一组文件,并通常表示为<fileset>元素。不过,许多ant任 务构建成了隐式的fileset,这说明他们支持所有的fileset属性和嵌套元素。以下为fileset 的属性列表。
(1).dir表示fileset 的基目录。
(2).casesensitive的值如果为false,那么匹配文件名时,fileset不是区分大小写的,其默认值为 true.
(3).defaultexcludes 用来确定是否使用默认的排除模式,默认为true。
(4).excludes 是用逗号分隔的需要派出的文件模式列表。
(5).excludesfile 表示每行包含一个排除模式的文件的文件名。
(6).includes 是用逗号分隔的,需要包含的文件模式列表。
(7).includesfile 表示每行包括一个包含模式的文件名。
5.patternset 类型
Fileset 是对文件的分组,而patternset是对模式的分组,他们是紧密相关的概念。<patternset> 支持4个属性:includes excludex includexfile 和 excludesfile,与fileset相同。 Patternset 还允许以下嵌套元素:include,exclude,includefile 和 excludesfile.
6.filterset 类型
Filterset定义了一组过滤器,这些过滤器将在文件移动或复制时完成文件的文本替换。主要属性如下:
(1).begintoken 表示嵌套过滤器所搜索的记号,这是标识其开始的字符串。
(2).endtoken表示嵌套过滤器所搜索的记号这是标识其结束的字符串。
(3).id是过滤器的唯一标志符。
(4).refid是对构建文件中某处定义一个过滤器的引用。
7.Path类型
Path元素用来表示一个类路径,不过它还可以用于表示其他的路径。在用作揖个属性时,路经中的各项用分号或冒号隔开。在构建 的时候,此分隔符将代替当前平台中所有的路径分隔符,其拥有的属性如下。
(1).location 表示一个文件或目录。Ant在内部将此扩展为一个绝对路径。
(2).refid 是对当前构建文件中某处定义的一个path的引用。
(3).path表示一个文件或路径名列表。
8.mapper类型
Mapper类型定义了一组输入文件和一组输出文件间的关系,其属性如下。
(1).classname 表示实现mapper类的类名。当内置mapper不满足要求时,用于创建定制mapper.
(2).classpath表示查找一个定制mapper时所用的类型路径。
(3).classpathref是对某处定义的一个类路径的引用。
(4).from属性的含义取决于所用的mapper.
(5).to属性的含义取决于所用的mapper.
(6).type属性的取值为identity,flatten glob merge regexp 其中之一,它定义了要是用的内 置mapper的类型。
关于构建文件有几点需要记住:
● 所有构建文件都要有<project>元素,而且至少有一个<target> 元素。
● 对于<project> 元素的default 属性并没有默认值。
● 构建文件并不一定要被命名为build.xml。不过build.xml 是Ant 要搜索的默认文件名。
● 每个构建文件只能有一个<project> 元素。
根据《ANT十五大最佳实践》,必须遵循以下几个原 则:
1. 采用一致的编码规范
精选含意明确、容易读懂的词汇来命名任务和属性。比如,dir.reports就比rpts好。特定的编码规范并不重要,只要拿出一套规范并坚持使用就 行。
2. 将build.xml放在项目根目录中
以下是一个典型的项目目录层次:
[root dir]
| build.xml
+–src
+–lib (包含第三方 JAR包)
+–build (由 build任务生成)
+–dist (由 build任务生成)
当build.xml在顶级目录时,假设你处于项目某个子目录中,只要输入:ant -find compile 命令,不需要改变工作目录就能够以命令行方式编译代码。参数-find告诉Ant寻找存在于上级目录中的build.xml并执行。
3. 使用单一的构建文件
4. 提供良好的帮助说明
5. 提供清除任务
6. 使用ANT管理任务从属关系
7. 定义并重用文件路径
8. 定义恰当的任务从属关系
9. 使用属性
10. 保持构建过程独立
11. 使用版本控制系统
12. 使用版本控制系统
13. 使用zipfileset属性
14. 测试Clean任务
15. 避免特定平台的Ant封装
MyEclipse自动生成Ant Build.xml
关于MyEclipse 自动生成 Ant Build.xml 配置文件,生成的方法很隐蔽,是自己无意中找到的.
选择你要生成Build.xml文件的项目,右键. Export-> General -> Ant Buildfiles .
点Next,再点Finish. OK,生成完毕.然后自己再根据需求去修改.