在netbeans中使用Ant在构建期间动态获取外部库的最新版本

时间:2013-06-13 04:23:29

标签: maven netbeans ant

我真是个蚂蚁新手。这是我的问题:我在netbeans中有一个项目,它使用当前存在于/ lib目录中的几个外部库。我希望我的netbeans在尝试构建项目时动态获取这些库的最新版本。这是可行的还是我走错了路? 我有每个外部库的URL,我需要在哪里指定那些才能使这个实验工作? 对此有任何帮助表示赞赏,我完全不知道如何做到这一点!

由于

大家好, 我检查了你所有的答案,并对它们进行了更多的搜索。现在的问题是虽然maven看起来很不可思议,但我的项目已经使用了Ant,我不知道如何从net上迁移到maven,以及它有多难。有帮助吗? 或者我可以将Apache Ivy用于此目的。 给你一个我正在使用的jar的例子: Apache commons jar

那么你们可以指导我如何解决这个问题吗?这个jar被包装在一个.zip文件中,所以我猜不容易检测最新版本。

2 个答案:

答案 0 :(得分:4)

get任务是使用标准ANT执行此操作的唯一方法。

现代开源开发的问题往往是一个jar依赖于几个,当一个人也必须跟踪版本兼容性时,这可能变得困难,如果不是不可能跟踪。

Maven是一种构建技术,它早于ANT,并具有针对第三方构建依赖项的依赖项管理功能。可以使用Apache ivy插件在ANT中复制此功能。

实施例

用于演示ivy的使用的Java项目:

├── build.xml
├── ivy.xml
└── src
    ├── main
    │   ├── java
    │   │   └── org
    │   │       └── demo
    │   │           └── App.java
    │   └── resources
    │       └── log4j.properties
    └── test
        └── java
            └── org
                └── demo
                    └── AppTest.java

还有一个额外的“ivy.xml”文件,其中列出了第三方依赖项。这些jar将默认从Maven Central repository下载,这是最大的开源Java jar存储库。

的ivy.xml

<ivy-module version="2.0">
    <info organisation="com.myspotontheweb" module="demo"/>

    <configurations>
        <conf name="compile" description="Required to compile application"/>
        <conf name="runtime" description="Additional run-time dependencies" extends="compile"/>
        <conf name="test"    description="Required for test only" extends="runtime"/>
    </configurations>

    <dependencies>
        <!-- compile dependencies -->
        <dependency org="org.slf4j" name="slf4j-api" rev="1.7.5" conf="compile->default"/>

        <!-- runtime dependencies -->
        <dependency org="org.slf4j" name="slf4j-log4j12" rev="1.7.5" conf="runtime->default"/>

        <!-- test dependencies -->
        <dependency org="junit" name="junit" rev="4.11" conf="test->default"/>
    </dependencies>

</ivy-module>

注意:

  • 此示例使用slf4j日志记录库,通过添加不同的jar,您可以在运行时选择实际的实现。
  • 常春藤文件声明3个“配置”,它们是依赖关系的逻辑分组。每个依赖项都有一个“conf”映射,告诉ivy jar将用于什么。
  • 在此示例中,我们的代码将针对slf4j-api jar进行编译,并将配置为在运行时使用log4j。
  • junit是ANT要求的第三方jar的示例。这些也可以由常春藤下载和管理。

的build.xml

<project name="demo" default="build" xmlns:ivy="antlib:org.apache.ivy.ant">

    <!--
    ================
    Build properties
    ================
    -->
    <property name="src.dir"          location="src/main/java"/>
    <property name="resources.dir"    location="src/main/resources"/>
    <property name="test.src.dir"     location="src/test/java"/>
    <property name="build.dir"        location="build"/>
    <property name="classes.dir"      location="${build.dir}/classes"/>
    <property name="test.classes.dir" location="${build.dir}/test-classes"/>
    <property name="ivy.reports.dir"  location="${build.dir}/ivy-reports"/>
    <property name="test.reports.dir" location="${build.dir}/test-reports"/>
    <property name="dist.dir"         location="${build.dir}/dist"/>

    <property name="jar.main.class" value="org.demo.App"/>
    <property name="jar.file"       value="${dist.dir}/${ant.project.name}.jar"/>

    <!--
    ===========
    Build setup
    ===========
    -->
    <target name="bootstrap" description="Install ivy">
        <mkdir dir="${user.home}/.ant/lib"/>
        <get dest="${user.home}/.ant/lib/ivy.jar" src="http://search.maven.org/remotecontent?filepath=org/apache/ivy/ivy/2.3.0/ivy-2.3.0.jar"/>
    </target>

    <target name="resolve" description="Use ivy to resolve classpaths">
        <ivy:resolve/>

        <ivy:report todir='${ivy.reports.dir}' graph='false' xml='false'/>

        <ivy:cachepath pathid="compile.path" conf="compile"/>
        <ivy:cachepath pathid="test.path"    conf="test"/>
    </target>

    <!--
    ===============
    Compile targets
    ===============
    -->
    <target name="resources" description="Copy resources into classpath">
        <copy todir="${classes.dir}">
            <fileset dir="${resources.dir}"/>
        </copy>
    </target>

    <target name="compile" depends="resolve,resources" description="Compile code">
        <mkdir dir="${classes.dir}"/>
        <javac srcdir="${src.dir}" destdir="${classes.dir}" includeantruntime="false" debug="true" classpathref="compile.path"/>
    </target>

    <target name="compile-tests" depends="compile" description="Compile tests">
        <mkdir dir="${test.classes.dir}"/>
        <javac srcdir="${test.src.dir}" destdir="${test.classes.dir}" includeantruntime="false" debug="true">
            <classpath>
                <path refid="test.path"/>
                <pathelement path="${classes.dir}"/>
            </classpath>
        </javac>
    </target>

    <!--
    ============
    Test targets
    ============
    -->
    <target name="test" depends="compile-tests" description="Run unit tests">
        <mkdir dir="${test.reports.dir}"/>
        <junit printsummary="yes" haltonfailure="yes">
            <classpath>
                <path refid="test.path"/>
                <pathelement path="${classes.dir}"/>
                <pathelement path="${test.classes.dir}"/>
            </classpath>
            <formatter type="xml"/>
            <batchtest fork="yes" todir="${test.reports.dir}">
                <fileset dir="${test.src.dir}">
                    <include name="**/*Test*.java"/>
                    <exclude name="**/AllTests.java"/>
                </fileset>
            </batchtest>
        </junit>
    </target>

    <!--
    =====================
    Build and run targets
    =====================
    -->
    <target name="build" depends="test" description="Create executable jar archive">
        <ivy:retrieve pattern="${dist.dir}/lib/[artifact]-[revision](-[classifier]).[ext]" conf="runtime"/>

        <manifestclasspath property="jar.classpath" jarfile="${jar.file}">
            <classpath>
                <fileset dir="${dist.dir}/lib" includes="*.jar"/>
            </classpath>
        </manifestclasspath>

        <jar destfile="${jar.file}" basedir="${classes.dir}">
            <manifest>
                <attribute name="Main-Class" value="${jar.main.class}" />
                <attribute name="Class-Path" value="${jar.classpath}" />
            </manifest>
        </jar>
    </target>

    <target name="run" depends="build" description="Run code">
        <java jar="${jar.file}" fork="true"/>
    </target>

    <!--
    =============
    Clean targets
    =============
    -->
    <target name="clean" description="Cleanup build files">
        <delete dir="${build.dir}"/>
    </target>

    <target name="clean-all" depends="clean" description="Additionally purge ivy cache">
        <ivy:cleancache/>
    </target>

</project>

有几项注意事项:

  • 默认情况下,蚂蚁不会发送常春藤罐。特殊的“bootstrap”目标用于将其下载到ANT用于插件的位置。
  • “resolve”目标包含用于下载(和缓存)依赖项的常春藤任务,生成有关这些文件的有用报告以及创建可用于编译和测试的ANT路径。
  • “build”目标包含常春藤“检索”任务,该任务将依赖项放入分发目录中。然后manifestclasspath可以使用它们为此构建创建的可执行jar文件生成正确的“类路径”清单条目。

答案 1 :(得分:1)

作为第一个建议,我会说蚂蚁可能不是最好的工具。 Maven正在这样做(至少如果您的外部库在(公共)maven repo中发布为SNAPSHOT)。此外,maven和netbeans可以很好地协同工作。

但是,如果你需要使用ant,你应该看一下ant get task。如果远程副本比本地副本(具有usetimestamp属性)更新,则允许您下载文件。所以这样的东西会在需要时进行下载:

<get src="http://some.url/somelib.jar" 
     dest="lib/somelib.jar"
     usetimestamp="true"/>