Ant之build.xml(三)

在Eclipse中使用Ant Ant是Java平台下非常棒的批处理命令执行程序,能非常方便地自动完成编译,测试,打包,部署等等一系列任务,大大提高开发效率。如果你现在还没有开始使用Ant,那就要赶快开始学习使用,使自己的开发水平上一个新台阶。 

Eclipse中已经集成了Ant,我们可以直接在Eclipse中运行Ant。 

以前面建立的Hello工程为例,创建以下目录结构: 

新建一个build.xml,放在工程根目录下。build.xml定义了Ant要执行的批处理命令。虽然Ant也可以使用其它文件名,但是遵循标准能更使开发更规范,同时易于与别人交流。 

通常,src存放Java源文件,classes存放编译后的class文件,lib存放编译和运行用到的所有jar文件,web存放JSP等web文件,dist存放打包后的jar文件,doc存放API文档。 

然后在根目录下创建build.xml文件,输入以下内容: 

Xml代码  

<?xml version="1.0"?>  

<project name="Hello world" default="doc">  

<!-- properies -->  

     <property name="src.dir" value="src" />  

     <property name="report.dir" value="report" />  

     <property name="classes.dir" value="classes" />  

     <property name="lib.dir" value="lib" />  

     <property name="dist.dir" value="dist" />  

<property name="doc.dir" value="doc"/>  

     <!-- 定义classpath -->  

     <path id="master-classpath">  

         <fileset file="${lib.dir}/*.jar" />  

         <pathelement path="${classes.dir}"/>  

     </path>  

     <!-- 初始化任务 -->  

     <target name="init">  

     </target>  

     <!-- 编译 -->  

     <target name="compile" depends="init" description="compile the source files">  

         <mkdir dir="${classes.dir}"/>  

         <javac srcdir="${src.dir}" destdir="${classes.dir}" target="1.4">  

             <classpath refid="master-classpath"/>  

         </javac>  

     </target>  

     <!-- 测试 -->  

     <target name="test" depends="compile" description="run junit test">  

         <mkdir dir="${report.dir}"/>  

         <junit printsummary="on"  

                 haltonfailure="false"  

                 failureproperty="tests.failed"  

                 showoutput="true">  

             <classpath refid="master-classpath" />  

             <formatter type="plain"/>  

             <batchtest todir="${report.dir}">  

                 <fileset dir="${classes.dir}">  

                     <include name="**/*Test.*"/>  

                 </fileset>  

             </batchtest>  

         </junit>  

         <fail if="tests.failed">  

         ***********************************************************   

         ****   One or more tests failed!   Check the output ...   ****   

         ***********************************************************   

         </fail>  

     </target>  

     <!-- 打包成jar -->  

     <target name="pack" depends="test" description="make .jar file">  

      <mkdir dir="${dist.dir}" />  

         <jar destfile="${dist.dir}/hello.jar" basedir="${classes.dir}">  

             <exclude name="**/*Test.*" />  

             <exclude name="**/Test*.*" />  

         </jar>  

     </target>  

     <!-- 输出api文档 -->  

     <target name="doc" depends="pack" description="create api doc">  

      <mkdir dir="${doc.dir}" />  

      <javadoc destdir="${doc.dir}"  

             author="true"  

             version="true"  

             use="true"  

             windowtitle="Test API">  

             <packageset dir="${src.dir}" defaultexcludes="yes">  

                 <include name="example/**" />  

             </packageset>  

             <doctitle><![CDATA[<h1>Hello, test</h1>]]></doctitle>  

             <bottom><![CDATA[<i>All Rights Reserved.</i>]]></bottom>  

             <tag name="todo" scope="all" description="To do:" />  

         </javadoc>  

     </target>  

</project>  

以上xml依次定义了init(初始化),compile(编译),test(测试),doc(生成文档),pack(打包)任务,可以作为模板。 

选中Hello工程,然后选择“Project”,“Properties”,“Builders”,“New…”,选择“Ant Build”: 

填入Name:Ant_Builder;Buildfile:build.xml;BaseDirectory:${workspace_loc: /Hello}(按“BrowseWorkspace”选择工程根目录),由于用到了junit.jar包,搜索Eclipse目录,找到 junit.jar,把它复制到Hello/lib目录下,并添加到Ant的Classpath中: 

然后在Builder面板中钩上Ant_Build,去掉Java Builder: 

再次编译,即可在控制台看到Ant的输出: 

Buildfile: F:\eclipse-projects\Hello\build.xml 

init: 

compile: 

        [mkdir] Created dir: F:\eclipse-projects\Hello\classes 

        [javac] Compiling 2 source files to F:\eclipse-projects\Hello\classes 

test: 

        [mkdir] Created dir: F:\eclipse-projects\Hello\report 

        [junit] Running example.HelloTest 

        [junit] Tests run: 1, Failures: 0, Errors: 0, Time elapsed: 0.02 sec 

pack: 

        [mkdir] Created dir: F:\eclipse-projects\Hello\dist 

          [jar] Building jar: F:\eclipse-projects\Hello\dist\hello.jar 

doc: 

        [mkdir] Created dir: F:\eclipse-projects\Hello\doc 

      [javadoc] Generating Javadoc 

      [javadoc] Javadoc execution 

      [javadoc] Loading source files for package example... 

      [javadoc] Constructing Javadoc information... 

      [javadoc] Standard Doclet version 1.4.2_04 

      [javadoc] Building tree for all the packages and classes... 

      [javadoc] Building index for all the packages and classes... 

      [javadoc] Building index for all classes... 

      [javadoc] Generating F:\eclipse-projects\Hello\doc\stylesheet.css... 

      [javadoc] Note: Custom tags that could override future standardtags:   @todo. To avoid potential overrides, use at least one periodcharacter (.) in custom tag names. 

      [javadoc] Note: Custom tags that were not seen:   @todo 

BUILD SUCCESSFUL 

Total time: 11 seconds 

Ant依次执行初始化,编译,测试,打包,生成API文档一系列任务,极大地提高了开发效率。将来开发J2EE项目时,还可加入部署等任务。并且,即使脱离了Eclipse环境,只要正确安装了Ant,配置好环境变量ANT_HOME=<Ant解压目录>, Path=…;%ANT_HOME%\bin,在命令行提示符下切换到Hello目录,简单地键入ant即可。

Ant 的最完整build.xml之标签:

Ant 开发 

Ant的构建文件 
   当开始一个新的项目时,首先应该编写Ant构建文件。构建文件定义了构建过程,并被团队开发中每个人使用。Ant构建文件默认命名为 build.xml,也可以取其他的名字。只不过在运行的时候把这个命名当作参数传给Ant。构建文件可以放在任何的位置。一般做法是放在项目顶层目录中,这样可以保持项目的简洁和清晰。下面是一个典型的项目层次结构。 
(1) src存放文件。 
(2) class存放编译后的文件。 
(3) lib存放第三方JAR包。 
(4) dist存放打包,发布以后的代码。 
Ant构建文件是XML文件。每个构建文件定义一个唯一的项目(Project元素)。每个项目下可以定义很多目标(target元素),这些目标之间可以有依赖关系。当执行这类目标时,需要执行他们所依赖的目标。每个目标中可以定义多个任务,目标中还定义了所要执行的任务序列。Ant在构建目标时必须调用所定义的任务。任务定义了Ant实际执行的命令。Ant中的任务可以为3类。 
(1) 核心任务。核心任务是Ant自带的任务。 
(2) 可选任务。可选任务实来自第三方的任务,因此需要一个附加的JAR文件。 
(3) 用户自定义的任务。用户自定义的任务实用户自己开发的任务。 
1.<project>标签 
  每个构建文件对应一个项目。<project>标签时构建文件的根标签。它可以有多个内在属性,就如代码中所示,其各个属性的含义分别如下。 
(1) default表示默认的运行目标,这个属性是必须的。 
(2) basedir表示项目的基准目录。 
(3) name表示项目名。 
(4) description表示项目的描述。 
每个构建文件都对应于一个项目,但是大型项目经常包含大量的子项目,每一个子项目都可以有自己的构建文件。 

2.<target>标签 
一个项目标签驴梢杂幸桓龌蚨喔?/span>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用来指定所创建的目录名,其代码如下: 
<mkdir dir=”${class.root}”/> 
通过以上代码就创建了一个目录,这个目录已经被前面的property标签所指定。 

4<jar>标签 
该标签用来生成一个JAR文件,其属性如下。 
(1) destfile表示JAR文件名。 
(2) basedir表示被归档的文件名。 
(3) includes表示别归档的文件模式。 
(4) exchudes表示被排除的文件模式。 

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 表示制定是否显示详细信息,默认值不显示。 

ant教程详解--javac,java,jar,war,delete,copy,mkdir:

Ant 是一个 Apache 基金会下的跨平台的构件工具,它可以实现项目的自动构建和部署等功能。在本文中,主要让读者熟悉怎样将 Ant 应用到 Java 项目中,让它简化构建和部署操作。 
一.              安装与配置 
下载地址: http://ant.apache.org/ ,在本文中下载的是 1.7.0 版本。解压到某个目录(例如 E:"apache-ant-1.7.0 ),即可使用。 
添加系统环境变量: ANT_HOME ,该变量指向 Ant 解压后的根目录,在此为 E:"apache-ant-1.7.0 。 
安装与配置完毕后,读者可以测试一下 Ant 是否可用,首先进入 Ant 的 bin 目录,运行命令 ant –version ,若安装和配置成功,则会显示 Ant 版本信息,如下图所示:

由上可以看出,读者运行 Ant 的命令时,需要进入到 Ant 的 bin 目录,如何才能让系统自动找到 Ant 呢?这时需要读者在系统环境变量 path 中添加 Ant 的 bin 目录。设置完成后,我们就可以在任何目录(例如 C:"Documents and Settings"AmigoXie 目录)输入 Ant 的命令,来获得命令的运行结果。 
二.              Ant 的关键元素 
Ant 的构件文件是基于 XML 编写的,默认名称为 build.xml 。为了更清楚的了解 Ant ,在这里编写一个简单的 Ant 程序,用来展现 Ant 的功能,让读者对 Ant 有一个初步的了解。首先在 E 盘下建立一个 build.xml 文件,内容如下: 
<? xml version="1.0" ?> 
< project  name ="helloWorld"> 
< target  name ="sayHelloWorld"> 
< echo  message ="Hello,Amigo"/> 
</ target > 
</ project > 
读者可以进入 E 盘,然后运行 ant sayHelloWorld ,可以看到如下的运行结果:

其中 sayHelloWorld 为需要执行的任务的名称。如果文件名不为 build.xml ,而为 hello.xml 时,读者运行同样的命令时,命令窗口会出现如下错误: 
Buildfile: build.xml does not exist! 
Build failed 
由上面的命令的错误提示可以看出, ant 命令默认寻找 build.xml 文件。若文件名为 hello.xml 时,读者还需要对命令做少许改变,改为: ant –f hello.xml sayHelloWorld 、 ant –buildfile hello.xml sayHelloWorld 或 ant –file hello.xml sayHelloWorld 。 
接下来开始向读者讲解本节的重点: Ant 的关键元素 project 、 target 、 property 和 task 。 
1.        project 元素 
project 元素是 Ant 构件文件的根元素, Ant 构件文件至少应该包含一个 project 元素,否则会发生错误。在每个 project 元素下,可包含多个 target 元素。接下来向读者展示一下 project 元素的各属性。 
1 ) name 属性 
用于指定 project 元素的名称。 
2 ) default 属性 
用于指定 project 默认执行时所执行的 target 的名称。 
3 ) basedir 属性 
用于指定基路径的位置。该属性没有指定时,使用 Ant 的构件文件的附目录作为基准目录。 
下面给读者一个简单的例子来展示 project 的各元素的使用。修改 E:"build.xml 文件,修改后的内容如下: 
<? xml version="1.0" ?> 
< project  name ="projectStudy"  default ="sayBaseDir"  basedir ="E:" apache-ant-1.7.0" > 
< target  name ="sayBaseDir"> 
< echo  message ="The base dir is: ${basedir}"/> 
</ target > 
</ project > 
从上面的内容我们可以看出,在这里定义了 default 属性的值为 sayBaseDir ,即当运行 ant 命令时,若未指明执行的 target 时,默认执行的 target 的 sayBaseDir ,同时还定义了 basedir 属性的值为 E:"apache-ant-1.7.0 ,进入 E 盘后运行 ant 命令,可看到运行的结果,如下图所示:

因为设定了 basedir 的值,所以 basedir 属性的值变成了读者设置的值。读者可以自行将 project 元素的 basedir 属性去掉后运行 ant 看看运行结果,此时 basedir 的值变成了 E:" ,即为 Ant 构件文件的父目录。 
有的时候,读者可能有这种需求,即想得到某个 project 下所有的 target 的名称,读者可以通过在 ant 命令里加上 -proecthelp 来达到该目的。例如针对上述的例子我们运行 ant –projecthelp ,输出结果如下: 
Buildfile: build.xml 
Main targets: 
Other targets: 
sayBaseDir 
Default target: sayBaseDir 
2.        target 元素 
它为 Ant 的基本执行单元,它可以包含一个或多个具体的任务。多个 target 可以存在相互依赖关系。它有如下属性: 
1 ) name 属性 
指定 target 元素的名称,这个属性在一个 project 元素中是唯一的。我们可以通过指定 target 元素的名称来指定某个 target 。 
2 ) depends 属性 
用于描述 target 之间的依赖关系,若与多个 target 存在依赖关系时,需要以“ , ”间隔。 Ant 会依照 depends 属性中 target 出现的顺序依次执行每个 target 。被依赖的 target 会先执行。 
3 ) if 属性 
用于验证指定的属性是否存在,若不存在,所在 target 将不会被执行。 
4 ) unless 属性 
该属性的功能与 if 属性的功能正好相反,它也用于验证指定的属性是否存在,若不存在,所在 target 将会被执行。 
5 ) description 属性 
该属性是关于 target 功能的简短描述和说明。 
下面带领读者来看一个各属性综合使用的例子。修改 E:"build.xml 文件,修改后的内容如下: 
<? xml version="1.0" ?> 
< project  name ="targetStudy"> 
< target  name ="targetA"  if ="ant.java.version"> 
< echo  message ="Java Version: ${ant.java.version}"/> 
</ target > 
< target  name ="targetB"  depends ="targetA"  unless ="amigo"> 
< description > 
a depend example!
</ description > 
< echo  message ="The base dir is: ${basedir}"/> 
</ target > 
</ project > 
进入 E 盘后运行 ant targetB ,可看到如下图所示的运行结果:

读者分析结果后可以看到,我们运行的是名为 targetB 的 target ,因该 target 依赖于 targetA ,所以 targetA 将首先被执行,同时因为系统安装了 java 环境,所以 ant.java.version 属性存在,执行了 targetA 这个 target ,输出信息: [echo] Java Version: 1.5 , targetA 执行完毕后,接着执行 targetB ,因为 amigo 不存在,而 unless 属性是在不存在时进入所在的 target 的,由此可知 targetB 得以执行,输出信息: The base dir is: E:" 。 
3.        property 元素 
该元素可看作参量或者参数的定义, project 的属性可以通过 property 元素来设定,也可在 Ant 之外设定。若要在外部引入某文件,例如 build.properties 文件,可以通过如下内容将其引入: <property file=” build.properties”/> 
property 元素可用作 task 的属性值。在 task 中是通过将属性名放在“ ${ ”和“ } ”之间,并放在 task 属性值的位置来实现的。 
Ant 提供了一些内置的属性,它能得到的系统属性的列表与 Java 文档中 System.getPropertis() 方法得到的属性一致,这些系统属性可参考 sun 网站的说明。 
同时, Ant 还提供了一些它自己的内置属性,如下: 
basedir : project 基目录的绝对路径,该属性在讲解 project 元素时有详细说明,不再赘述; 
ant.file : buildfile 的绝对路径,如上面的各例子中, ant.file 的值为 E:"build.xml ; 
ant.version : Ant 的版本,在本文中,值为 1.7.0 ; 
ant.project.name :当前指定的 project 的名字,即前文说到的 project 的 name 属性的值; 
ant.java.version : Ant 检测到的 JDK 的版本,在上例运行结果中可看到为 1.5 。 
下面让读者来看一个 property 元素使用的简单例子。修改 E:"build.xml 文件,内容如下: 
<? xml version="1.0" ?> 
< project  name ="propertyStudy"  default ="example"> 
< property  name ="name"  value ="amigo"/> 
< property  name ="age"  value ="25"/> 
< target  name ="example"> 
< echo  message ="name: ${name}, age: ${age}"/> 
</ target > 
</ project > 
该例的运行结果如下图所示:

由此读者可以看出,通过如下两个语句: 
<property name="name" value="amigo"/> 
<property name="age" value="25"/> 
我们设置了名为 name 和 age 的两个属性,这两个属性设置后,读者在下文中可以通过 ${name} 和 ${age} 分别取得这两个属性的值。 
三.              Ant 的常用任务 
在 Ant 工具中每一个任务封装了具体要执行的功能,是 Ant 工具的基本执行单位。在本小节中,主要引导读者来看下 Ant 的常用任务及其使用举例。 
1.        copy 任务 
该任务主要用来对文件和目录的复制功能。举例如下: 
Eg1. 复制单个文件: <copy file="file.txt" tofile="copy.txt"/> 
Eg2. 对文件目录进行复制: 
<copy todir="../newdir/dest_dir"> 
<fileset dir="src_dir"/> 
</copy> 
Eg3. 将文件复制到另外的目录: 
<copy file="file.txt" todir="../other/dir"/> 
2.        delete 任务 
对文件或目录进行删除,举例如下: 
Eg1. 删除某个文件: <delete file="photo/amigo.jpg"/> 
Eg2. 删除某个目录: <delete dir="photo"/> 
Eg3. 删除所有的备份目录或空目录: 
<delete includeEmptyDirs="true"> 
<fileset dir="." includes="**/*.bak"/> 
</delete> 
3.        mkdir 任务 
创建目录。 eg : <mkdir dir="build"/> 
4.        move 任务 
移动文件或目录,举例如下: 
Eg1. 移动单个文件: <move file="fromfile" tofile=”tofile”/> 
Eg2. 移动单个文件到另一个目录: <move file="fromfile" todir=”movedir”/> 
Eg3. 移动某个目录到另一个目录: 
<move todir="newdir"> 
<fileset dir="olddir"/> 
</move> 
5.        echo 任务 
该任务的作用是根据日志或监控器的级别输出信息。它包括 message 、 file 、 append 和 level 四个属性,举例如下: 
<echo message="Hello,Amigo" file="logs/system.log" append="true"> 
四.              利用 Ant 构建和部署 Java 工程 
Ant 可以代替使用 javac 、 java 和 jar 等命令来执行 java 操作,从而达到轻松的构建和部署 Java 工程的目的。下面来看几个知识点。 
1.        利用 Ant 的 javac 任务来编译 java 程序 
Ant 的 javac 任务用于实现编译 Java 程序的功能。下面来看一个简单的例子: 
首先我们建立名为 antstudy 的 Java 工程,建立 src 目录为源代码目录,在 src 目录下建立 HelloWorld.java 这个类文件。该类文件的内容如下: 
public   class  HelloWorld  {
public   static   void  main(String[] args)  {
System.out.println("Hello,Amigo");
}

同时在 antstudy 工程的根目录下建立 build.xml 文件,在该文件中编译 src 目录下的 java 文件,并将编译后的 class 文件放入 build/classes 目录中,在编译前,需清除 classes 目录,该文件的内容如下: 
<? xml version="1.0" ?> 
< project  name ="javacTest" default ="compile"  basedir ="."> 
< target  name ="clean"> 
< delete  dir ="build"/> 
</ target > 

< target  name ="compile"  depends ="clean"> 
< mkdir  dir ="build/classes"/> 
< javac  srcdir ="src"  destdir ="build/classes"/> 
</ target > 
</ project > 
运行该 build.xml 文件,可在工程中看到新增了 build/classes 目录,并在该目录中生成了编译后的 HelloWorld.class 文件。 
2.        使用 Ant 的 java 任务运行 Java 程序 
Ant 中可以使用 java 任务实现运行 Java 程序的功能。下面在 1 的例子中进行如下的修改,修改后的 build.xml 文件的内容如下: 
<? xml version="1.0" ?> 
< project  name ="javaTest"  default ="jar"  basedir ="."> 
< target  name ="clean"> 
< delete  dir ="build"/> 
</ target > 

< target  name ="compile"  depends ="clean"> 
< mkdir  dir ="build/classes"/> 
< javac  srcdir ="src"  destdir ="build/classes"/> 
</ target > 

< target  name ="run"  depends ="compile"> 
< java  classname ="HelloWorld"> 
< classpath > 
< pathelement  path ="build/classes"/> 
</ classpath > 
</ java > 
</ target > 
</ project > 
运行该 build.xml 文件,可在控制台看到 HelloWorld 的 main 方法的输出。 
3.        使用 Ant 的 jar 任务生成 jar 文件 
读者可以在上例的基础上更进一步,来生成 jar 包,可在 run 这个 target 下再加上如下 target : 
< target  name ="jar"  depends ="run"> 
< jar  destfile ="helloworld.jar"  basedir ="build/classes"> 
< manifest > 
< attribute  name ="Main-class"  value ="HelloWorld"/> 
</ manifest > 
</ jar > 
</ target > 
此时将 ant 的 project 的 default 属性设置为 jar ,同时运行该 build.xml 文件,运行完毕后,可看到在工程目录下生成了一个 jar 包 HelloWorld.jar 。 
4.        使用 Ant 的 war 任务打包 J2EE Web 项目 
建立一个 J2EE Web 工程,其目录结构如下图所示:
其中 src 为源代码目录, WebRoot 为各 jsp 存放目录, lib 为工程的包目录。在 antwebproject 工程目录下建立了 build.xml 文件,该文件为该工程的 Ant 构件文件。读者可以 src 目录下放入在前续例子中开发的 HelloWorld.java 文件,并在 WebRoot 下建立 index.jsp 文件,其内容很简单,就是输出 Hello 信息,代码如下所示: 
<% @ page language="java" contentType="text/html; charset="UTF-8" pageEncoding="UTF-8" %> 
<! DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd" > 
< html > 
< head > 
< meta  http-equiv ="Content-Type"  content ="text/html; charset=ISO-8859-1"> 
< title > ant 打包测试 </ title > 
</ head > 
< body > 
Hello,Ant
</ body > 
</ html > 
接下来编写 build.xml 文件,其内容如下: 
<? xml version="1.0" ?> 
< project  name ="antwebproject"   default ="war" basedir ="."> 
< property  name ="classes"  value ="build/classes"/> 
< property  name ="build" value ="build"/> 
< property  name ="lib" value ="WebRoot/WEB-INF/lib"/> 
<!--  删除build 路径--> 
< target  name ="clean"> 
< delete  dir ="build"/> 
</ target > 

<!--  建立build/classes 路径,并编译class 文件到build/classes 路径下--> 
< target  name ="compile"  depends ="clean"> 
< mkdir  dir ="${classes}"/> 

< javac  srcdir ="src"  destdir ="${classes}"/> 
</ target > 

<!--  打war 包--> 
< target  name ="war"  depends ="compile"> 
< war  destfile ="${build}/antwebproject.war"  webxml ="WebRoot/WEB-INF/web.xml"> 
<!--  拷贝WebRoot 下除了WEB-INF 和META-INF 的两个文件夹--> 
< fileset  dir ="WebRoot"  includes ="**/*.jsp"/> 

<!--  拷贝lib 目录下的jar 包--> 
< lib  dir ="${lib}"/> 
<!--  拷贝build/classes 下的class 文件--> 
< classesdir ="${classes}"/> 
</ war > 
</ target > 
</ project > 
各 target 的作用在内容中已经进行说明,在此不再赘述。运行该 build 文件,更新目录后,可看到在 build 目录下生成了 antwebproject.war 文件,解开后可看到其目录结构如下: 
--META-INF 
--MANIFEST.MF 
--index.jsp 
--WEB-INF 
--lib 
--log4j-1.2.9.jar 
--classes 
--HelloWorld.class 
--web.xml 
读者可以将该 war 包拷贝到 Tomcat 的目录下看一下运行结果。 
五.              总结 
在本文中,笔者由浅至深详细描述了 Ant 的安装与配置、关键元素和常用任务。并通过实例讲述了 Ant 在我们 Java 项目中的应用,讲述了编译、运行 java 程序,以及打 jar 包、 war 包等知识,引领读者进入 Ant 的奇妙世界。在本文中可以看到, Ant 在自动构建和部署 Java 程序方面方便易用,而且非常灵活,不失为我们 Java 开发者的绝佳帮手

猜你喜欢

转载自blog.csdn.net/guoguo527/article/details/53164209