`
azheng270
  • 浏览: 93439 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

ANT的安装/配置笔记

阅读更多
ANT的安装/配置笔记
作者:车东发表于:2003-03-0617:03最后更新于:2007-04-1211:04
版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明。
http://www.chedong.com/tech/ant.html
--------------------------------------------------------------------------------
内容摘要:
ant是一个基于JAVA的自动化脚本引擎,脚本格式为XML。除了做JAVA编译相关任务外,ANT还可以通过插件实现很多应用的调用。


ANT的基本概念:
ANT的安装:解包,设置路径
ANT的使用:最好的学习只不过是一个简单实用的例子起步……
ANT的基本概念:Java的Makefile
当一个代码项目大了以后,每次重新编译,打包,测试等都会变得非常复杂而且重复,因此c语言中有make脚本来帮助这些工作的批量完成。在Java中应用是平台无关性的,当然不会用平台相关的make脚本来完成这些批处理任务了,ANT本身就是这样一个流程脚本引擎,用于自动化调用程序完成项目的编译,打包,测试等。除了基于JAVA是平台无关的外,脚本的格式是基于XML的,比make脚本来说还要好维护一些。


每个ant脚本(缺省叫build.xml)中设置了一系列任务(target):比如对于一个一般的项目可能需要有以下任务。

任务1:usage打印本脚本的帮助信息(缺省)
任务2:clean
<--init清空初始化环境
任务3:javadoc<--build<--init生成JAVADOC
任务4:jar<--build<--init生成JAR
任务5:all<--jar+javadoc<--build<--init完成以上所有任务:jarjavadoc
而多个任务之间往往又包含了一定了依赖关系:比如把整个应用打包任务(jar)的这个依赖于编译任务(build),而编译任务又依赖于整个环境初始化任务(init)等。

注:我看到很多项目的ant脚本中的命名基本上都是一致的,比如:编译一般叫build或者compile;打包一般叫jar或war;生成文档一般命名为javadoc或javadocs;执行全部任务all。在每个任务的中,ANT会根据配置调用一些外部应用并配以相应参数执行。虽然ANT可调用的外部应用种类非常丰富,但其实最常用的就2,3个:比如javacjavadocjar等。
ANT的安装
解包后在系统可执行路径中加入指向ant的bin的路径就可以了,比如可以在GNU/Linux上把以下配置加入/etc/profile中:
exportANT_HOME
=/home/ant
exportJAVA_HOME=/usr/java/j2sdk1.4.1
exportPATH=$PATH:$JAVA_HOME/bin:$ANT_HOME/bin

这样执行ant后,如果不指定配置文件ant会缺省找build.xml这个配置文件,并根据配置文件执行任务,缺省的任务设置可以指向最常用的任务,比如:build,或指向打印帮助信息:usage,告诉用户有那些脚本选项可以使用。


ANT的使用

最好的学习过程就是看懂那些opensource项目中的build.xml脚本,然后根据自己的需要简化成一个更简单的,ANT和APACHE上很多非常工程派的项目:简单易用,而且适应性非常强,因为这些项目的建立往往来源于开发人员日常最直接的需求。
以下是的一个WebLucene应用的例子:修改自JDOM的build.xml:

<projectdefault
="usage"basedir=".">

<!--===================================================================-->
<!--Initializationtarget-->
<!--===================================================================-->
<targetname="init">
<tstamp/>
<propertyfile="${basedir}/build.properties"/>
<propertyname="Name"value="ProjectFullName"/>
<propertyname="name"value="project_name"/>
<propertyname="version"value="0.2"/>
<propertyname="year"value="2003"/>

<echomessage="-----------${Name}${version}[${year}]------------"/>

<propertyname="debug"value="off"/>
<propertyname="optimize"value="on"/>
<propertyname="deprecation"value="on"/>

<propertyname="src.dir"value="./src/WEB-INF/src"/>
<propertyname="lib.dir"value="./src/WEB-INF/lib"/>
<propertyname="packages"value="com.chedong.*,org.apache.lucene.*"/>

<propertyname="build.src"value="./src/WEB-INF/build"/>
<propertyname="build.dest"value="./src/WEB-INF/classes"/>
<propertyname="build.javadocs"value="./src/doc"/>

<pathid="classpath">
<pathelementpath="${jsdk_jar}"/>
<filesetdir="${lib.dir}">
<includename="**/*.jar"/>
</fileset>
</path>

<filtertoken="year"value="${year}"/>
<filtertoken="version"value="${version}"/>
<filtertoken="date"value="${TODAY}"/>
<filtertoken="log"value="true"/>
<filtertoken="verbose"value="true"/>
</target>

<!--===================================================================-->
<!--Helponusage-->
<!--===================================================================-->
<targetname="usage"depends="init">
<echomessage="${Name}Buildfile"/>
<echomessage="-------------------------------------------------------------"/>
<echomessage=""/>
<echomessage="availabletargetsare:"/>
<echomessage=""/>
<echomessage="jar-->generatesthe${name}.jarfile"/>
<echomessage="build-->compilesthesourcecode"/>
<echomessage="javadoc-->generatestheAPIdocumentation"/>
<echomessage="clean-->cleansupthedirectory"/>
<echomessage=""/>
<echomessage="Pleaserenamebuild.properties.defaulttobuild.properties"/>
<echomessage="andeditbuild.propertiestospecifyJSDK2.3classpath."/>
<echomessage=""/>
<echomessage="Seethecommentsinsidethebuild.xmlfileformoredetails."/>
<echomessage="-------------------------------------------------------------"/>
<echomessage=""/>
<echomessage=""/>
</target>

<!--===================================================================-->
<!--Preparesthesourcecode-->
<!--===================================================================-->
<targetname="prepare-src"depends="init">
<!--createdirectories-->
<mkdirdir="${build.src}"/>
<mkdirdir="${build.dest}"/>

<!--copysrcfiles-->
<copytodir="${build.src}">
<filesetdir="${src.dir}"/>
</copy>
</target>

<!--===================================================================-->
<!--Compilesthesourcedirectory-->
<!--===================================================================-->
<targetname="build"depends="prepare-src">
<javacsrcdir="${build.src}"
destdir
="${build.dest}"
debug
="${debug}"
optimize
="${optimize}">
<classpathrefid="classpath"/>
</javac>
</target>

<!--===================================================================-->
<!--Createstheclasspackage-->
<!--===================================================================-->
<targetname="jar"depends="build">
<jarjarfile="${lib.dir}/${name}.jar"
basedir
="${build.dest}"
includes
="**"/>
</target>

<!--===================================================================-->
<!--CreatestheAPIdocumentation-->
<!--===================================================================-->
<targetname="javadoc"depends="build">
<mkdirdir="${build.javadocs}"/>
<javadocpackagenames="${packages}"
sourcepath
="${build.src}"
destdir
="${build.javadocs}"
author
="true"
version
="true"
use
="true"
splitindex
="true"
windowtitle
="${Name}API"
doctitle
="${Name}">
<classpathrefid="classpath"/>
</javadoc>
</target>

<!--===================================================================-->
<!--Cleantargets-->
<!--===================================================================-->
<targetname="clean"depends="init">
<deletedir="${build.src}"/>
<deletedir="${build.dest}/org"/>
<deletedir="${build.dest}/com"/>
<delete>
<filesetdir="${build.dest}"includes="**/*.class"/>
</delete>
</target>
</project>
<!--Endoffile-->

缺省任务:usage打印帮助文档,告诉有那些任务选项:可用的有build,jar,javadoc和clean.

初始化环境变量:init
所有任务都基于一些基本环境变量的设置初始化完成,是后续其他任务的基础,在环境初始化过程中,有2点比较可以方便设置:

1除了使用却缺省的property设置了JAVA源路径和输出路径外,引用了一个外部的build.properties文件中的设置,
<propertyfile="${basedir}/build.properties"/>
这样大部分简单配置用户只要会看懂build.properties就可以了,毕竟XML比起keyvalue的属性文件还是要可读性差一些。用build.properties也可以方便其他用户从编译的细节中解放出来。

2CLASSPATH设置:使用了其中的:
<pathid="classpath">
<pathelementpath="${jsdk_jar}"/>
<filesetdir="${lib.dir}">
<includename="**/*.jar"/>
</fileset>
</path>
则相当于设置了:CLASSPATH=/path/to/resin/lib/jsdk23.jar;/path/to/project/lib/*.jar;

文件复制:prepare-src
创建临时SRC存放目录和输出目录。
<!--===================================================================-->
<!--Preparesthesourcecode-->
<!--===================================================================-->
<targetname="prepare-src"depends="init">
<!--createdirectories-->
<mkdirdir="${build.src}"/>
<mkdirdir="${build.dest}"/>

<!--copysrcfiles-->
<copytodir="${build.src}">
<filesetdir="${src.dir}"/>
</copy>
</target>

编译任务:build
编译时的CLASSPATH环境通过一下方式找到引用一个path对象
<classpathrefid="classpath"/>

打包任务:jar
对应用打包生成项目所写名的.jar文件
<!--===================================================================-->
<!--Createstheclasspackage-->
<!--===================================================================-->
<targetname="jar"depends="build">
<jarjarfile="${lib.dir}/${name}.jar"
basedir
="${build.dest}"
includes
="**"/>
</target>

生成JAVADOC文档任务:javadoc
<!--===================================================================-->
<!--CreatestheAPIdocumentation-->
<!--===================================================================-->
<targetname="javadoc"depends="build">
<mkdirdir="${build.javadocs}"/>
<javadocpackagenames="${packages}"
sourcepath
="${build.src}"
destdir
="${build.javadocs}"
author
="true"
version
="true"
use
="true"
splitindex
="true"
windowtitle
="${Name}API"
doctitle
="${Name}">
<classpath
分享到:
评论

相关推荐

    ant的安装配置笔记

    下面将详细介绍Ant的基本概念、安装配置以及使用方法。 **Ant的基本概念** Ant的全称是Apache Ant,它的核心理念是通过XML描述的构建脚本来自动化Java项目的构建过程。在XML文件(通常名为`build.xml`)中,开发者...

    Ant安装配置笔记.doc

    ANT的安装: 1. **解压**:下载ANT的zip或tar.gz文件,解压缩到本地目录。 2. **设置环境变量**:将ANT的bin目录添加到系统的PATH环境变量中,这样在任何位置都可以直接运行ANT命令。 ANT的使用: 1. **默认脚本**...

    Jenkins+SVN+Ant持续集成环境配置笔记

    ### Jenkins+SVN+Ant持续集成环境配置笔记 #### 一、引言 随着软件开发项目的日益复杂化,持续集成(Continuous Integration, CI)已成为现代软件工程中的一个重要组成部分。通过持续集成,团队能够频繁地集成代码...

    Jenkins+SVN+Ant持续集成环境配置笔记.pdf

    在Jenkins项目配置中指定Ant的脚本文件位置,Jenkins就会在触发构建时执行这个脚本,完成项目的自动化构建。这样,开发者只需将代码提交到SVN仓库,Jenkins就会自动进行后续的构建工作,从而实现持续集成。 在整个...

    ant_学习笔记

    ### ant学习笔记:深入了解ant构建工具 #### 引言 `ant`,作为一款源自动网络的学习笔记,主要探讨了Apache Ant这一强大的构建工具。Apache Ant是一款开源的、跨平台的构建工具,专为Java应用程序设计,旨在简化并...

    Ant 1.9.1 学习笔记

    Ant 1.9.1是Ant的一个版本,学习笔记通常记录了使用该工具的基本操作和配置方法。 ### Ant的下载和安装 要使用Ant,首先需要下载并安装。在Windows系统中,通常需要配置环境变量以便于命令行中使用Ant命令。ANT_...

    Ant构建工具学习笔记

    本文将深入探讨Ant的基本概念、安装配置、使用方法以及自定义任务。 一、Ant的基本概念与功能 Ant是一个基于XML的构建工具,它的核心是构建脚本,通常以build.xml命名。这个脚本定义了一系列的任务(Task),每个...

    经典ant笔记.doc

    ### 经典Ant笔记知识点详解 #### 一、Ant简介及功能 - **定义与作用:** - Ant是一款开源的Java平台上的自动化构建工具,主要用于简化软件项目的构建过程,支持多种任务,如编译Java源代码、运行Java程序、复制...

    ant个人学习笔记和简单示例

    总的来说,这个“ant个人学习笔记和简单示例”应该能帮助你掌握Ant的基本用法,理解构建过程的自动化,以及如何编写和维护自己的构建文件。通过学习和实践其中的示例,你将能够熟练地运用Ant来构建和管理Java项目,...

    ant 学习 笔记 一个简单的java 编译部署实例

    ### 安装与配置Ant 在提供的内容中,首先提到了Ant的安装路径为`D:\apache-ant-1.7.1`,并设置了环境变量`ANT_HOME`指向此路径,同时将`%ANT_HOME%\bin`目录添加到系统路径中。这一步骤是Ant正常工作的基础,确保了...

    ant的学习笔记.doc

    ### ant的学习笔记知识点详解 #### 一、Ant的作用与特性 Ant是一款强大的自动化构建工具,主要应用于Java项目,能够高效地处理项目的编译、打包、测试等任务。它采用XML格式编写构建脚本,这使得Ant具有良好的跨...

    Mongodb安装与配置笔记

    本文主要讨论如何在Linux环境下安装和配置MongoDB。 1. 下载与安装MongoDB MongoDB的安装首先需要从其官方网站下载对应操作系统的二进制包。在Linux环境下,可以使用wget或scp命令将文件从一个已下载的机器复制到...

    Ant打包编译部署工具学习笔记2(附件中含有测试项目)

    在"Ant打包编译部署工具学习笔记2"中,我们可以预期博主分享了关于如何利用Ant进行更复杂的构建操作,例如集成测试、优化和打包。这可能包括如何配置build.xml文件,添加自定义任务,以及如何处理依赖关系。由于没有...

    微信小程序 备忘录/笔记本ant_noteBook-master.zip

    3. **项目结构**:在“ant_noteBook-master”目录下,通常会有`app.js`、`app.json`、`app.wxss`这三个核心文件,分别代表小程序的全局配置、全局JSON配置和全局样式。此外,还有`pages`目录,其中包含各个页面的...

    Ant学习笔记

    **Ant学习笔记** Ant是一个基于Java的构建工具,它的全称是Another Neat Tool,主要应用于Java项目的构建。Ant的设计理念是通过XML配置文件来定义构建过程,而非依赖于特定平台的shell命令。每个构建任务是由实现了...

    Ant速学笔记.doc

    Apache Ant 是一个开源的构建工具,广泛用于Java项目,它基于XML来定义任务,使得构建过程可配置且可复用。在本文档中,我们主要关注Ant在创建和管理Java项目中的基本应用,特别是如何使用它来编写CC(可能是持续...

    运动器材通信协议 ANT+各种协议

    2. **应用笔记**:这些文档提供了针对特定应用场景的指导,如如何设置一个心率带,或者如何将ANT+协议集成到自行车速度和踏频传感器中。它们通常包含实例代码和配置步骤,对开发者非常有帮助。 3. **开发者工具**:...

Global site tag (gtag.js) - Google Analytics