首页 > 代码库 > Ant入门之引用外部jar文件
Ant入门之引用外部jar文件
笔者在java项目开发中经常遇到引用外部Jar包的情况,使用ant打包过程中需要对其引用。现在此简单记忆以飨来者。
此处引用Log4j,具体程序HelloLog4j.java:
package oata;import org.apache.log4j.Logger;import org.apache.log4j.BasicConfigurator;public class HelloLog4j { static Logger logger = Logger.getLogger(HelloLog4j.class); public static void main(String[] args) { BasicConfigurator.configure(); logger.info("Hello Log4j"); }}
MyMath具体程序:
package com.iie.test.ant;public class MyMath { public int multi(int number1, int number2) { return number1 * number2; }}
Main.java具体程序:
package com.iie.test.ant;public class Main { public static void main(String[] args) { MyMath math = new MyMath(); System.out.println("Result is: " + math.multi(5, 10)); }}
builder文件:
<?xml version="1.0" encoding="UTF-8"?><!--project 用于定义一个ant工程,其中的三项name、default、basedir缺一不可。作用分别为:定义工程名、制定默认执行的任务、以及工程基础的路径型(它是计算其它路径的基础,一般情况下使用.即在java工程根目录即可)--><project name="HelloWorld" default="jar" basedir="."> <!--描述,个人觉得就是一提示作用,没什么实际用途--> <description>use jar test</description> <!--定义源文件路径,其中的value换成location也行,使用value的时候,${src}得到的就是src这个值,如果使用location,得到的是src这个目录的绝对路径--> <property name="src" value="http://www.mamicode.com/src" /> <property name="classes" value="http://www.mamicode.com/bin/classes" /> <!--构造打包时Class-Path需要的路径 --> <!--pathconvert用于对目录进行组合 property即这个组合的名字,pathsep作用是各个文件之间的分隔符, 如果不写,在windows平台默认是分号。但时在MANIFEST.MF这个文件中,各个jar包之间要用空格区分, 因此。这里就写成空格了 --> <pathconvert property="lib" pathsep=" "> <!--mapper,对路径组合方式进行控制--> <mapper> <!--chainedmapper 作用是联合多个mapper--> <chainedmapper> <!--过滤文件,将路径去掉,只保留文件名--> <flattenmapper /> <!--过滤+转换器,将所有的文件名前面都加上一个lib,我们知道lib目录下面有jar包, lib/*的作用其实是将jar包名与路径进行组合形成如:lib/google.jar这样的相对路径 --> <globmapper from="*" to="lib/*" /> </chainedmapper> </mapper> <!--按照mapper定义的格式组合lib目录下面的所有jar文件,形成诸如lib/jar1.jar lib/jar2.jar的字符串--> <fileset dir="lib"> <include name="*.jar" /> </fileset> </pathconvert> <!--组合各个路径,构成MANIFEST.MF文件中Class-Path所需的字符串--> <property name="libs" value="http://www.mamicode.com/${lib}" /> <!--打印一下刚才构造好的字符串,看看是否符合要求--> <echo>libs ${libs}</echo> <!-- 构造打包时Class-Path需要的路径 结束--> <!--创建任务init,负责初始化一些条件--> <target name="init"> <!-- 创建存放编译后的class的目录 mkdir可以创建多级目录 --> <mkdir dir="${classes}" /> </target> <!--创建编译任务,名字是compile,depends指定了comiple任务依赖init任务--> <target name="compile" depends="init" description="comile target"> <!--javac,编译,对应java中的javac命令。 其中srcdir定义源文件路径 destdir定义编译后文件路径, includeantruntime作用是指定编译任务是否包含ant的classpath,可有可无,不影响编译, 但不写可能会出现警告,为了眼不见心不烦,加上吧--> <javac srcdir="${src}" destdir="${classes}" includeantruntime="true"> <!-- classpath 定义编译需要的claspath --> <classpath> <fileset dir="lib"> <include name="*.jar" /> </fileset> </classpath> </javac> </target> <!--打包开始,名字为jar,依赖任务为compile--> <target name="jar" depends="compile" description="make jar file"> <!--jar操作,jarfile指定jar包存放路径,basedir为编译后的class的目录--> <property name="jarfilename" value="http://www.mamicode.com/HelloLog4j.jar" /> <jar jarfile="${jarfilename}" basedir="${classes}"> <!--为jar包指定manifest,当然,如果jar包不需要打成runnable的形式,manifest可以不要--> <manifest> <!--指定main-class--> <attribute name="Main-Class" value="http://www.mamicode.com/oata.HelloLog4j" /> <!--指定Class-Path--> <attribute name="Class-Path" value="http://www.mamicode.com/${libs}"> </attribute> </manifest> </jar> <property name="jarfilename2" value="http://www.mamicode.com/Main.jar" /> <!--jar操作,jarfile指定jar包存放路径,basedir为编译后的class的目录--> <jar jarfile="${jarfilename2}" basedir="${classes}"> <!--为jar包指定manifest,当然,如果jar包不需要打成runnable的形式,manifest可以不要--> <manifest> <!--指定main-class--> <attribute name="Main-Class" value="http://www.mamicode.com/com.iie.test.ant.Main" /> <!--指定Class-Path--> <attribute name="Class-Path" value="http://www.mamicode.com/${libs}"> </attribute> </manifest> </jar> </target> <!--运行一下jar包,试试看效果--> <target name="run" depends="jar"> <!--其实这里就是运行jar命令,注意fork一定加上,不然不起作用--> <java jar="${jarfilename}" fork="true"> </java> <java jar="${jarfilename2}" fork="true"> </java> </target> <!-- 清理 --> <target name="clean"> <!-- 可以以递归的方式删除目录 --> <delete dir="${classes}" /> <delete dir="." includes="${ant.project.name}*.jar" /> </target></project>
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。