MAVEN引入第三方JAR包

本文介绍三种处理无法从Maven仓库获取依赖JAR包的方法:使用system scope指定本地路径;上传至自建Maven仓库;编译时指定外部lib路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方式1:   
dependency 本地JAR包

适用环境:自己没有搭建MAVEN仓库服务器,或者 将JAR包传入到服务器,无法下载的情况

在POM.XML中加入

<dependency>
    <groupId>com.gxhs.analysis2</groupId>  <!-随便写->
    <artifactId>netty-client-distributed</artifactId> <!-随便写->
    <version>2.0</version>  <!-随便写->
    <scope>system</scope> <!--system,类似provided,需要显式提供依赖的jar以后,Maven就不会在Repository中查找它-->
    <systemPath>${basedir}/lib/netty-client-distributed-2.0.jar</systemPath> <!--项目根目录下的lib文件夹下-->
</dependency>

basedir 常量 代表 POM文件所在工程的文件夹地址

方式2:将JAR包传入到MAVEN仓库服务器的 第3方仓库中

1.  可以通过  http://ip:8081/nexus 管理页面  上传到服务器
2.  通过命令行 上传JAR包  
mvn install:install-file -DgroupId=org.jboss.cache -DartifactId=jbosscache-core -Dversion=3.2.7.GA -Dpackaging=jar -Dfile=D:\jbosscache-core-3.2.7.GA.jar

一些参数说明如下:
-DgroupId=远程仓库对应的DgroupId
-DartifactId= 远程仓库对应的 DartifactId 
-Dversion=对应版本号

在POM.XML中直接引入
<dependency>
<groupId>com.gxhs.analysis2</groupId>
<artifactId>netty-client-distributed</artifactId>
<version>2.0</version>
</dependency>

方式3: 编译时指定外部lib
   <plugin>
     <artifactId>maven-compiler-plugin</artifactId>
     <configuration>
     <source>1.8</source>
     <target>1.8</target>
     <encoding>UTF-8</encoding>
     <compilerArguments>
     <extdirs>${project.basedir}/src/main/webapp/WEB-INF/lib</extdirs><!--指定外部lib-->
     </compilerArguments>
     </configuration>
     </plugin>





### 如何在 Java Maven 项目中添加和配置第三方 JAR 文件 #### 方法一:通过 POM.XML 添加依赖项 如果目标第三方 JAR 已经存在于公共 Maven 仓库或者私有远程仓库,则可以直接在 `pom.xml` 中声明其依赖关系。例如: ```xml <dependency> <groupId>com.wst</groupId> <artifactId>wst-hsm-api</artifactId> <version>1.7.3</version> </dependency> ``` 上述代码片段展示了如何将名为 `wst-hsm-api` 的 JAR 作为项目的依赖引入[^1]。 --- #### 方法二:安装本地 JAR 到本地 Maven 仓库 当所需的第三方 JAR 不在任何可用的 Maven 远程仓库中时,可以将其手动安装至本地 Maven 仓库。执行以下命令即可完成操作: ```bash mvn install:install-file -Dfile=<path-to-file> -DgroupId=<group-id> \ -DartifactId=<artifact-id> -Dversion=<version> -Dpackaging=jar ``` 其中 `<path-to-file>` 是实际 JAR 文件路径;其他参数如 `groupId`, `artifactId`, 和 `version` 都需自行指定。完成后,在 `pom.xml` 中按照常规方式引用此 JAR 即可。 --- #### 方法三:利用 system 范围直接引用本地 JAR 另一种方法是在项目根目录下创建一个专门用于存储这些外部库的新文件夹(比如命名为 libs),并将所需 JAR 放置于此处。接着修改 `pom.xml` 来指明这个位置以及对应的坐标信息: ```xml <dependency> <groupId>com.hikvision.building.cloud</groupId> <artifactId>consumer</artifactId> <version>1.1.1</version> <scope>system</scope> <systemPath>${project.basedir}/libs/consumer-1.1.1.jar</systemPath> </dependency> ``` 这种方法适用于那些仅限于当前工程使用的特殊类库情况[^3]。 --- #### 方法四:调整 IDEA 设置以便支持第三方 jar 对于某些特定需求场景下的开发环境(例如 IntelliJ IDEA),还需要进一步设置才能确保最终产物能够正确含所有必要的组件。这通常涉及到了解并合理运用构建工具的相关插件功能。下面是一个典型例子展示怎样借助 Spring Boot 插件实现这一点: ```xml <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <!-- 让 maven 编译的时候能将第三方编入 --> <configuration> <includeSystemScope>true</includeSystemScope> </configuration> </plugin> ``` 这里的关键在于设置了 `<includeSystemScope>` 属性为 true ,从而允许系统范围内的依赖被纳入打过程之中[^2]。 --- ### 总结 以上介绍了四种不同的途径来解决 “如何向基于 Maven 构建体系之上的 Java 应用程序加入额外的非标准库”的问题。每种方案都有各自适用场合及其优缺点考量因素存在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值