当前位置: 首页 > news >正文

IDEA Maven 手动替换第三方Jar包完整教程

一、前言

平时开发中,大部分依赖直接在 Maven 写坐标即可自动下载。但是有一类 Jar 包永远无法从公共仓库下载:商业授权 SDK、闭源第三方 Jar、公司内部工具包,例如 SuperMap、ArcGIS、国产中间件等。

本次我以SuperMap 超图 Jar 升级替换为例,完整记录 Maven 手动安装、替换 Jar 的全过程,以及大量新手必踩坑点。

二、常见误区:为什么普通依赖不用安装,SuperMap 需要?

1. 公共开源包(无需手动安装)

例如:Spring、Mybatis、Mysql、Lombok、Hutool。

  • 存放在:阿里云仓库 / Maven 中央仓库

  • 使用方式:直接改版本号,刷新 Maven 自动下载

  • 不需要任何命令,不需要本地 Jar

2. 商业/私有 Jar(必须手动安装)

例如:SuperMap、ArcGIS、付费SDK、自研Jar。

  • 公共仓库没有资源

  • Maven 无法联网下载

  • 必须开发者手动把 Jar 放入本地 Maven 仓库

  • 手动放入仓库的动作:mvn install:install-file 安装

三、完整实操步骤(替换 SuperMap 为例)

1. 准备工作

拿到新版本的若干 Jar 包,本次用到超图5个核心依赖:

  • com.supermap.data

  • com.supermap.data.conversion

  • com.supermap.mapping

  • com.supermap.layout

  • com.supermap.analyst.spatialanalyst

2. 环境要求(新手必看)

必须配置 Maven 系统环境变量,保证 CMD 输入mvn -v能识别。

踩坑:IDEA 内置 PowerShell 不会加载最新环境变量,建议使用系统CMD执行安装命令。

3. Jar 命名规范(非常重要)

Jar 文件名必须带版本号,例如:

com.supermap.data-12.0.1.jar

原因:Maven 依赖定位规则:groupId + artifactId + version,三者必须严格匹配。

如果不带版本号,安装命令识别不到文件,直接报错:文件不存在。

4. 执行安装命令

将 Jar 放入 pom.xml 同级目录,CMD 进入当前项目目录。

示例单条安装命令:

mvn install:install-file -Dfile=com.supermap.data-12.0.1.jar -DgroupId=com.supermap -DartifactId=com.supermap.data -Dversion=12.0.1 -Dpackaging=jar

出现 BUILD SUCCESS 代表安装成功。

4.1 补充:一定要在 pom.xml 同级目录执行吗?

结论:不是必须,但新手强烈建议放在同级目录。

1、原理直白解释

Maven 安装命令中-Dfile=xxx.jar是相对路径:

你当前 CMD 在哪一个文件夹,它就去哪一个文件夹找 Jar。

如果你写的是单纯文件名(不带完整路径),Jar 就必须和 CMD 工作目录保持一致。

2、为什么教程都放 pom 同级?

  • 路径最简单,不用写超长绝对路径

  • 不容易出现Jar not exists文件找不到报错

  • 方便管理临时 Jar,安装完统一删除

3、不在同级目录怎么写?(进阶写法)

可以放在任意磁盘位置,只要写绝对路径,示例:

mvn install:install-file -Dfile=E:\jar\com.supermap.data-12.0.1.jar -DgroupId=com.supermap -DartifactId=com.supermap.data -Dversion=12.0.1 -Dpackaging=jar

4、误区提醒

安装命令不需要依赖 pom.xml,哪怕没有 pom 文件,这条命令照样能把 Jar 装进 Maven 仓库。

很多人误以为必须在项目目录执行,这是错误认知。

唯一限制:文件路径必须写对。

5. 安装完成后,原始Jar可以删除吗?

可以直接删除!!!

安装本质:把Jar复制一份放入你的 Maven 本地仓库(例如 D:\MavenRepository)。

项目后续编译、运行、打包,全部读取仓库内的文件,项目目录下的原始Jar只是临时安装介质,无任何作用。

6. IDEA 刷新依赖

右侧 Maven 面板 → 刷新按钮,依赖红叉消失,版本替换完成。

四、本次踩坑大全(强烈收藏)

  1. PowerShell 无法识别 mvn
    原因:PowerShell 不会实时加载新配置的环境变量,解决方案:使用系统CMD。

  2. 提示xxx.jar not exists
    原因:文件名不一致、没有版本号、路径不对。

  3. mvnw 命令报错
    原因:普通Maven项目没有mvnw脚本,不要无脑复制网上教程。

  4. 明明装了依赖还是爆红
    解决方案:刷新Maven、清除IDEA缓存、重启项目。

五、通俗易懂总结(直白人话)

  1. 公共开源包:改版本号+刷新,无需安装。

  2. 商业私有包:必须手动mvn安装进本地仓库。

  3. 安装命令本质:复制Jar+登记坐标。

  4. 安装完原始Jar可以删除,不影响项目。

  5. Jar名称必须带版本号,严格匹配pom依赖。

  6. 新手尽量用系统CMD,不要用IDEA终端。

六、附加:通用安装模板(可永久收藏)

mvn install:install-file -Dfile=你的jar文件名.jar -DgroupId=公司组名 -DartifactId=项目名 -Dversion=版本号 -Dpackaging=jar
http://www.jsqmd.com/news/886820/

相关文章:

  • 告别手动测试!用CANoe.Diva自动化诊断测试,从CDD文件到完整报告保姆级流程
  • 双系统Ubuntu磁盘告急?别重装!用GParted无损扩容保姆级教程(附U盘启动盘制作)
  • 智能体所有权与版权:AI Agent Harness Engineering 创造的作品归谁所有?
  • Lovable电商网站搭建陷阱大全(2024最新版):Nuxt 3 SSR失效、Stripe Webhook丢包、SEO结构坍塌三大隐形杀手曝光
  • 2026五金电子门牌技术解析:电子去向牌/礼品兑换柜/社区兑换柜/五育兑换柜/人员去向电子牌/会议电子门牌/塑胶电子门牌/选择指南 - 优质品牌商家
  • 2026论文降AI怎么挑?亲测好用工具附免费降AI指南
  • DeepSeek代码质量断崖式下滑真相(2024真实生产事故复盘):从token泄漏到推理延迟的11处重构盲区
  • Performance-Fish:为《环世界》注入流畅灵魂的革命性性能优化方案
  • 2026最新Java面试复盘:1000道高频八股文+65个真实场景题(含手写源码+解答思路)
  • 2026年5月全屋定制品牌推荐:五大口碑测评环保耐用专业价格 - 品牌推荐
  • Taotoken平台快速获取APIKey并开始你的第一个Python调用示例
  • RAG从入门到精通:Naive RAG带你秒懂检索生成技术精髓!
  • Burp Suite深度解析:从流量抓包到业务逻辑漏洞挖掘
  • NoFences桌面分区工具:免费高效的Windows桌面图标管理终极指南
  • DeepSeek-R1/VL多模态集成测试难点突破:图像-文本联合断言、上下文状态追踪与延迟敏感型验证
  • Windows 11安卓子系统:3个关键技巧让你电脑秒变“双系统手机“
  • 2026年5月北京二手房装修公司推荐:TOP5专业评测老房翻新防踩坑注意事项价格 - 品牌推荐
  • Selenium爬取微博热搜完整实战:从环境搭建到反爬绕过的全流程踩坑指南
  • AutoDock-Vina终极指南:5步掌握免费分子对接神器
  • 研0导师不教你 但你要会的组会汇报
  • claude code的替代
  • 别再手动拼Prompt了!LangChain4j的ChatMemory和AiServices才是Java聊天机器人的正确打开方式
  • DeepSeek代码风格检查实战手册,从零配置到生产级规则定制全流程
  • 告别async/await测试焦虑:用pytest-asyncio插件搞定Python异步代码测试(附完整示例)
  • DIY高精度GPS驯服钟:用OCXO与单片机打造实验室级频率基准
  • DeepSeek边缘安全沙箱深度拆解(含SEV-SNP启用失败根因分析与SGX2迁移路径)
  • DeepSeek v3升级迫在眉睫?立即启用这套已验证的灰度集成测试方案——支撑日均200万请求的稳定性护城河
  • Qt项目里图片加载太慢?试试用QOpenGLWidget+GPU加速,性能提升不止一点点
  • 抖音下载器终极指南:如何快速批量下载无水印视频
  • 0.2毫秒快速启动的操作系统