Maven - 外部依赖



如您所知,Maven 使用仓库的概念进行依赖管理。但是,如果依赖项在任何远程仓库和中央仓库中都不可用,会发生什么情况?Maven 通过 **外部依赖** 的概念为这种情况提供了解决方案。

例如,让我们对“创建 Java 项目”章节中创建的项目进行以下更改。

  • 在 src 文件夹中添加 **lib** 文件夹。

  • 将任何 jar 文件复制到 lib 文件夹中。我们使用了 **ldapjdk.jar**,它是一个用于 LDAP 操作的辅助库。

现在我们的项目结构应如下所示:

external repository project structure

这里您拥有自己的库,特定于项目,这是一种常见情况,它包含一些 jar 文件,这些 jar 文件可能在任何 Maven 可以下载的仓库中都不可用。如果您的代码使用此库与 Maven 结合,则 Maven 构建将失败,因为它无法在编译阶段下载或引用此库。

为了处理这种情况,让我们使用以下方法将此外部依赖项添加到 Maven 的 **pom.xml** 中。

<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/maven-v4_0_0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.companyname.bank</groupId>
   <artifactId>consumerBanking</artifactId>
   <packaging>jar</packaging>
   <version>1.0-SNAPSHOT</version>
   <name>consumerBanking</name>
   <url>http://maven.apache.org</url>

   <dependencies>
      <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>3.8.1</version>
         <scope>test</scope>
      </dependency>

      <dependency>
         <groupId>ldapjdk</groupId>
         <artifactId>ldapjdk</artifactId>
         <scope>system</scope>
         <version>1.0</version>
         <systemPath>${basedir}\src\lib\ldapjdk.jar</systemPath>
      </dependency>
   </dependencies>

</project>

查看上面示例中 dependencies 下的第二个 dependency 元素,它阐明了关于 **外部依赖** 的以下关键概念。

  • 外部依赖项(库 jar 文件位置)可以在 pom.xml 中以与其他依赖项相同的方式进行配置。

  • 将 groupId 指定为库名称。

  • 将 artifactId 指定为库名称。

  • 将 scope 指定为 system。

  • 指定相对于项目位置的系统路径。

希望现在您已经了解了外部依赖项,并且能够在您的 Maven 项目中指定外部依赖项。

广告