首页 > 其他 > 详细

Ant入门之引用外部jar文件

时间:2014-08-15 19:28:59      阅读:381      评论:0      收藏:0      [点我收藏+]

  笔者在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="src" />
    <property name="classes" value="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="${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="HelloLog4j.jar" />
        <jar jarfile="${jarfilename}" basedir="${classes}">
            <!--为jar包指定manifest,当然,如果jar包不需要打成runnable的形式,manifest可以不要-->
            <manifest>
                <!--指定main-class-->
                <attribute name="Main-Class" value="oata.HelloLog4j" />
                <!--指定Class-Path-->
                <attribute name="Class-Path" value="${libs}">
                </attribute>
            </manifest>
        </jar>
        
        <property name="jarfilename2" value="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="com.iie.test.ant.Main" />
                <!--指定Class-Path-->
                <attribute name="Class-Path" value="${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>

 

Ant入门之引用外部jar文件,布布扣,bubuko.com

Ant入门之引用外部jar文件

原文:http://www.cnblogs.com/Gingber/p/3915491.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!