Ant之build.xml(三)

简介: 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 开发者的绝佳帮手


相关文章
|
7月前
|
存储 安全 Java
Maven3.8.*系列 settings.xml详解
Maven3.8.*系列 settings.xml详解
321 0
|
5月前
cordova config.xml
cordova config.xml
|
6月前
|
Java 定位技术 Maven
Maven Settings.xml 的语法详解
Maven Settings.xml 的语法详解
77 0
|
6月前
|
XML 存储 Java
关于 Maven 的 Settings.xml 文件
关于 Maven 的 Settings.xml 文件
366 0
|
Java Maven
Maven: settings.xml、pom.xml完整配置
Maven: settings.xml、pom.xml完整配置
1682 0
|
XML Java Linux
Ant之build.xml详解(一)
Ant之build.xml详解(一)
|
XML 开发框架 前端开发
Ant之build.xml(二)
Ant之build.xml(二)
Java构建工具Ant之第一个build.xml
Java构建工具Ant之第一个build.xml
|
XML 前端开发 Java
一个ant的build.xml文件记录
尽管现在公司maven,gradle占主流。 但ant还是有一些的。 对于不是java的项目打包的问题, ant就更有通用性了。
1290 0

相关课程

更多