- Apache ANT 教程
- ANT - 首页
- ANT - 简介
- ANT - 环境设置
- ANT - 构建文件
- ANT - 属性任务
- ANT - 属性文件
- ANT - 数据类型
- ANT - 构建项目
- ANT - 构建文档
- ANT - 创建 JAR 文件
- ANT - 创建 WAR 文件
- ANT - 打包应用程序
- ANT - 部署应用程序
- ANT - 执行 Java 代码
- ANT - Eclipse 集成
- ANT - JUnit 集成
- ANT - 扩展 Ant
- Apache ANT 常用示例
- ANT - 使用 Token
- ANT - 使用命令行参数
- ANT - 使用 If Else 语句
- ANT - 自定义组件
- ANT - 监听器和日志记录器
- Apache ANT 资源
- ANT - 快速指南
- ANT - 有用资源
- ANT - 讨论
Ant - 打包应用程序
我们已经分阶段学习了使用Hello World Fax Web 应用程序的 Ant 的不同方面。
现在,是时候将所有内容整合在一起,创建一个完整且完整的 build.xml 文件了。请考虑如下所示的build.properties 和build.xml 文件:
build.properties
build.properties 文件如下所示:
deploy.path=c:\tomcat6\webapps
build.xml
build.xml 文件如下所示:
<?xml version="1.0"?> <project name="fax" basedir="." default="usage"> <property file="build.properties"/> <property name="src.dir" value="src"/> <property name="web.dir" value="war"/> <property name="javadoc.dir" value="doc"/> <property name="build.dir" value="${web.dir}/WEB-INF/classes"/> <property name="name" value="fax"/> <path id="master-classpath"> <fileset dir="${web.dir}/WEB-INF/lib"> <include name="*.jar"/> </fileset> <pathelement path="${build.dir}"/> </path> <target name="javadoc"> <javadoc packagenames="faxapp.*" sourcepath="${src.dir}" destdir="doc" version="true" windowtitle="Fax Application"> <doctitle><![CDATA[<h1>= Fax Application =</h1>]]></doctitle> <bottom><![CDATA[Copyright © 2011. All Rights Reserved.]]></bottom> <group title="util packages" packages="faxapp.util.*"/> <group title="web packages" packages="faxapp.web.*"/> <group title="data packages" packages="faxapp.entity.*:faxapp.dao.*"/> </javadoc> </target> <target name="usage"> <echo message=""/> <echo message="${name} build file"/> <echo message="-----------------------------------"/> <echo message=""/> <echo message="Available targets are:"/> <echo message=""/> <echo message="deploy --> Deploy application as directory"/> <echo message="deploywar --> Deploy application as a WAR file"/> <echo message=""/> </target> <target name="build" description="Compile main source tree java files"> <mkdir dir="${build.dir}"/> <javac destdir="${build.dir}" source="1.5" target="1.5" debug="true" deprecation="false" optimize="false" failonerror="true"> <src path="${src.dir}"/> <classpath refid="master-classpath"/> </javac> </target> <target name="deploy" depends="build" description="Deploy application"> <copy todir="${deploy.path}/${name}" preservelastmodified="true"> <fileset dir="${web.dir}"> <include name="**/*.*"/> </fileset> </copy> </target> <target name="deploywar" depends="build" description="Deploy application as a WAR file"> <war destfile="${name}.war" webxml="${web.dir}/WEB-INF/web.xml"> <fileset dir="${web.dir}"> <include name="**/*.*"/> </fileset> </war> <copy todir="${deploy.path}" preservelastmodified="true"> <fileset dir="."> <include name="*.war"/> </fileset> </copy> </target> <target name="clean" description="Clean output directories"> <delete> <fileset dir="${build.dir}"> <include name="**/*.class"/> </fileset> </delete> </target> </project>
在上例中:
我们首先在 build 属性文件中将 Tomcat 中 webapps 文件夹的路径声明为deploy.path 变量。
我们还声明了 Java 文件的源文件夹为src.dir 变量。
然后,我们将 Web 文件的源文件夹声明为web.dir 变量。javadoc.dir 是用于存储 Java 文档的文件夹,build.dir 是用于存储构建输出文件的路径。
之后,我们声明 Web 应用程序的名称,在本例中为fax。
我们还定义了主类路径,其中包含项目 WEB-INF/lib 文件夹中存在的 JAR 文件。
我们还在主类路径中包含build.dir 中存在的类文件。
Javadoc 目标生成项目所需的 javadoc,而 usage 目标用于打印构建文件中存在的常用目标。
以上示例显示了两个部署目标:deploy 和deploywar。
deploy 目标将文件从 web 目录复制到 deploy 目录,同时保留最后修改的日期时间戳。这在部署到支持热部署的服务器时非常有用。
clean 目标清除所有先前构建的文件。
deploywar 目标构建 war 文件,然后将 war 文件复制到应用程序服务器的 deploy 目录。
广告