- Apache IVY 教程
- Apache IVY - 主页
- Apache IVY - 概述
- Apache IVY - 环境设置
- Apache IVY - 术语
- Apache IVY - 设置文件
- Apache IVY - Eclipse Ivy 插件
- ANT Ivy 任务
- Apache IVY - 解决
- Apache IVY - 安装
- Apache IVY - 检索
- Apache IVY - 缓存路径
- Apache IVY - 发布
- Apache IVY - 信息
- 存储库
- Apache IVY - 解析器
- Apache IVY - 本地存储库
- Apache IVY - 共享存储库
- Apache IVY - 公共存储库
- Apache IVY 有用资源
- Apache IVY - 快速指南
- Apache IVY - 有用的资源
- Apache IVY - 讨论
Apache IVY - 解析器
解析器用于查找要下载库的位置。依赖关系解析器还处理常见任务。Ivy 提供两种类型的解析器。
复合- 使用其他解析器来完成其任务的解析器。
标准- 解析器执行所需的任务。
标准旋转变压器
下表列出了标准解析器及其用法。
先生。 | 名称(类型)和描述 |
---|---|
1 | IvyRep(标准) 在 ivyrep 上找到 Ivy 文件,在 ibiblio 上找到工件。 |
2 | IBiblio(标准) 在 ibiblio 上找到文物。 |
3 | 垃圾箱(标准) 定位 bintray 上的工件。 |
4 | 包装机(标准) 通过 URL 定位 Ivy 文件和打包说明,使用说明创建工件。 |
5 | 文件系统(标准) 定位本地文件系统上的 Ivy 文件和工件。 |
6 | 网址(标准) 定位存储库上的 Ivy 文件和工件,可以使用 URL 访问这些文件和工件。 |
7 | 镜像URL(标准) 定位存储库上的 Ivy 文件和工件,可以使用镜像列表中的 URL 访问这些文件和工件。 |
8 | VFS(标准) 定位存储库上的 Ivy 文件和工件,可以使用 Apache Commons VFS 访问这些文件和工件。 |
9 | SSH(标准) 找到可以使用 SSH 访问的存储库上的 Ivy 文件和工件。 |
10 | SFTP(标准) 定位存储库上的 Ivy 文件和工件,可以使用 SFTP 访问这些文件和工件。 |
11 | 罐子(标准) 在 jar 内的存储库中查找 Ivy 文件和工件。 |
12 | 链条(复合) 将搜索委托给一系列子解析器。 |
13 | 双(复合) 将搜索委托给一个解析器,并将工件委托给另一个解析器。 |
14 | OBR(标准) 将模块解析为 OSGi obr.xml 列出的 OSGi 捆绑包。 |
15 | Eclipse 更新站点(标准) 将模块解析为托管在 Eclipse 更新站点上的 OSGi 捆绑包。 |
16 | OSGi-agg(复合) 将搜索委托给支持 OSGi 包的子解析器链。 |
让我们在E:> ivy2文件夹下的新项目中创建 Tester.java、build.xml 和 ivy.xml,类似于IVY - 解决任务章节中所述。在E:> ivy2下创建一个 settings 文件夹。在设置文件夹中创建 ivysettings.xml。
构建.xml
<project name="test" default="resolve" xmlns:ivy="antlib:org.apache.ivy.ant"> <property name = "build.dir" value = "build"/> <property name = "base.dir" value = ""/> <target name="resolve" description="resolve dependencies"> <ivy:resolve /> </target> <target name="compile" depends="resolve" description="Compile"> <mkdir dir="build/classes" /> <javac srcdir="src" destdir="build/classes"> <classpath refid="new.classpath" /> </javac> </target> </project>
常春藤.xml
<?xml version="1.0" encoding="ISO-8859-1"?> <ivy-module version="2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="http://ant.apache.org/ivy/schemas/ivy.xsd"> <info organisation="org.apache" module="chained-resolvers"/> <dependencies> <dependency org="commons-lang" name="commons-lang" rev="2.6" conf="default"/> <dependency org="com.tutorialspoint" name="test" rev="1.0"/> </dependencies> </ivy-module>
这里我们添加了两个依赖项,一个是 commons-lang 库,另一个是我们在IVY - 发布任务章节中发布的测试。
ivy设置.xml
<ivysettings> <settings defaultResolver="multiresolver"/> <resolvers> <chain name="multiresolver"> <filesystem name="libraries"> <artifact pattern="${ivy.settings.dir}/repository/[artifact]-[revision].[ext]"/> </filesystem> <ibiblio name="ibiblio" m2compatible="true"/> </chain> </resolvers> </ivysettings>
在这里,我们添加了使用链解析器创建的复合解析器,它有两个解析器,一个命名库用于在本地存储库上查找库,另一个名为 ibiblio 在 maven 公共存储库上。
构建项目
因为我们已经准备好了所有文件。只需进入控制台即可。导航到E:> ivy2文件夹并运行 ant 命令。
E:\ivy > ant
Ivy 将开始行动,解决依赖关系,您将看到以下结果。
Buildfile: E:\ivy2\build.xml resolve: [ivy:resolve] :: Apache Ivy 2.5.0 - 20191020104435 :: https://ant.apache.org/ivy / :: [ivy:resolve] :: loading settings :: url = jar:file:/E:/Apache/apache-ant-1.9.14 /lib/ivy-2.5.0.jar!/org/apache/ivy/core/settings/ivysettings.xml [ivy:resolve] :: resolving dependencies :: org.apache#chained-resolvers;working@ Acer-PC [ivy:resolve] confs: [default] [ivy:resolve] found commons-lang#commons-lang;2.6 in public [ivy:resolve] found com.tutorialspoint#test;1.0 in local [ivy:resolve] found junit#junit;3.8.1 in public [ivy:resolve] downloading C:\Users\Acer\.ivy2\local\com.tutorialspoint\test\1.0\ jars\application.jar ... [ivy:resolve] .. (1kB) [ivy:resolve] .. (0kB) [ivy:resolve] [SUCCESSFUL ] com.tutorialspoint#test;1.0!application.jar (13ms) [ivy:resolve] :: resolution report :: resolve 1085ms :: artifacts dl 22ms --------------------------------------------------------------------- | | modules || artifacts | | conf | number| search|dwnlded|evicted|| number|dwnlded| --------------------------------------------------------------------- | default | 3 | 3 | 1 | 0 || 5 | 1 | --------------------------------------------------------------------- BUILD SUCCESSFUL Total time: 9 seconds
在日志中,您可以验证我们是否使用了本地和公共存储库解析器。