0

0

如何在 Gradle 项目中将本地 JAR 文件作为资源嵌入并共享依赖

碧海醫心

碧海醫心

发布时间:2026-02-22 13:39:00

|

614人浏览过

|

来源于php中文网

原创

如何在 Gradle 项目中将本地 JAR 文件作为资源嵌入并共享依赖

本文介绍如何通过 gradle 的 files() 依赖声明方式,将本地 .jar 文件以资源形式纳入构建产物,实现离线环境下的多模块依赖共享,避免重复打包与远程仓库依赖。

本文介绍如何通过 gradle 的 files() 依赖声明方式,将本地 .jar 文件以资源形式纳入构建产物,实现离线环境下的多模块依赖共享,避免重复打包与远程仓库依赖。

在多模块 Java/Gradle 项目中,有时需要将某个通用工具库(如内部 SDK 或定制化组件)以原始 JAR 形式分发给多个子模块,并确保它们在运行时统一加载同一份最新版 JAR(而非各自 Shade 进去),同时支持完全离线构建。此时,不应使用 shaded 或 shadowJar 方式将依赖“打平”进主 JAR,而应将其作为可访问的资源文件嵌入最终产物,并由类加载器动态加载。

Gradle 提供了简洁可靠的机制来实现这一目标:使用 files() 声明文件依赖。该方式不触发远程仓库解析,完全基于本地路径,天然适配离线场景:

// build.gradle (Kotlin DSL 示例)
dependencies {
    implementation(files("libs/shared-utils-1.2.0.jar"))
}
// build.gradle (Groovy DSL)
dependencies {
    implementation(files("libs/shared-utils-1.2.0.jar"))
}

关键说明

Motiff
Motiff

Motiff是由猿辅导旗下的一款界面设计工具,定位为“AI时代设计工具”

下载
  • files(...) 声明的 JAR 会自动加入编译与运行时 classpath,且 Gradle 会将其复制到 build/libs/ 输出目录中(若配合 application 或自定义 distZip 插件),也可通过 processResources 任务显式拷贝至 src/main/resources/ 下供运行时读取;
  • 若需在运行时以 ClassLoader.getSystemResource() 或 getResourceAsStream() 加载该 JAR 中的资源(如配置文件、模板等),建议额外配置 copy 任务,确保其随主应用一同发布:
// 将指定 JAR 复制到最终资源输出目录(如 src/main/resources/lib/)
tasks.processResources {
    from("libs/shared-utils-1.2.0.jar") {
        into "lib"
        rename { "shared-utils.jar" } // 统一命名便于运行时定位
    }
}

对于多模块项目,只需在每个子模块的 build.gradle 中重复声明相同的 files(...) 依赖即可——Gradle 不会重复下载,也不会产生版本冲突,因为路径指向的是同一份本地文件。

⚠️ 重要注意事项

  • 不要尝试在运行时“比较 JAR 版本号并动态加载最新版”:这不仅增加复杂度,还易引发类加载隔离、签名验证失败、资源覆盖等问题;推荐由构建流程统一管控版本(如通过 CI/CD 更新 libs/ 目录 + Git 提交);
  • 若需彻底禁用网络请求(例如断网调试),可在执行时添加 --offline 参数:./gradlew build --offline;
  • files(...) 依赖不会参与传递性依赖解析,因此它仅提供该 JAR 内部的类与资源,不自动拉取其自身的依赖项——如有需要,请手动补全或改用 flatDir 仓库(不推荐,已过时)。

综上,files() 是轻量、可靠、符合 Gradle 惯例的解决方案,兼顾离线性、可维护性与运行时灵活性,是共享本地 JAR 资源的最佳实践。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

894

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

575

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

273

2023.07.24

git提交错误怎么撤回
git提交错误怎么撤回

git提交错误撤回的方法:git reset head^:撤回最后一次提交,恢复到提交前状态。git revert head:创建新提交,内容与之前提交相反。git reset :使用提交的 sha-1 哈希撤回指定提交。交互式舞台区:标记要撤回的特定更改,然后提交,排除已撤回更改。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

566

2024.04.09

git怎么对比两个版本的文件内容
git怎么对比两个版本的文件内容

要对比两个版本的 git 文件,请使用 git diff 命令:git diff 比较工作树和暂存区之间的差异。git diff 比较两个提交或标签之间的差异。git diff 输出显示差异块,其中 + 表示添加的行,- 表示删除的行, 表示修改的行。可使用 gitkraken、meld、beyond compare 等可视化工具更直观地查看差异。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

530

2024.04.09

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1006

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

317

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

211

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

34

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号