Gradle发布依赖包到Github仓库

上周接了个需求,需要把项目中一个模块打包发布到git上供其他项目使用。
大无语,查了一大堆真的是醉醉的,乱七八糟没有一个好使的,最后还是官方文档靠谱啊,xdm,以后有需求先查官方文档啊!!!
我个人认为,写博客不光是为了记录,同时最好也能帮别人解决一些问题,只有这样一篇博客才多少有点价值吧,写到哪种程度呢,最好是饭都送到嘴边那种程度!!!这样自己回过头来看的时候,也不会一脸懵。
下面想详细说一下gradle发布依赖包到github仓库的具体步骤。
请保证访问github畅通,最好网络好一点,因为上传和下载如果网络不佳,是很可能失败的。

第一步:修改配置

(此处是单个包,多个包参考官网,区别不大,官网地址文末会放)在你需要发布的模块的build.gradle文件中,添加下列代码:
在这里插入图片描述

plugins {
    id 'maven-publish'
}
publishing {
    repositories {
        maven {
            name = "GitHubPackages"
            url = uri("https://maven.pkg.github.com/jwcxs-m/jarproject")
            credentials {
                username = System.getenv("GITHUB_ACTOR")
                password = System.getenv("GITHUB_TOKEN")
            }
        }
    }

    publications {
        gpr(MavenPublication) {
            from(components.java)
        }
    }
}

username和password我这里配了环境变量,如果嫌麻烦甚至可以在发包的时候直接给定值,像下面这样:

credentials {
                username = "Damon"
                password = "ghp_7asdwrc123dsww34YyqkkpP1jHzvR"
            }

注意:如果直接填写了token,不要把token直接提交到github仓库中,不然github会检测到你的token被上传到项目里,就强行给你把token停用了!!!

然后就是说password,就是这个token咋生成的:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
最后拉到最下方,点这个绿的一键生成。
在这里插入图片描述
生成后的token复制出来,因为只有第一次能看到,下次进来就看不到了。然后把token设置给上面的password就行。

第二步:发布

找个喜欢的地方(常用终端或者是IDEA里的终端都行…),直接执行gradle publish(不出意外的话,就会看到发布成功,出意外了再说…)
乌鱼子,刚说完就报错了…

Failed to publish publication 'gpr' to repository 'GitHubPackages'
 Could not PUT 'https://maven.pkg.github.com/jwcxs-m/tjar/io/dingodb/d/0.1.0-SNAPSHOT/d-0.1.0-20220316.024713-3.jar'. Received status code 422 from server: Unprocessable Entity

一开始我以为是项目的问题,就尝试重新在github上新建项目,然后试了有2次都不行。
就换了个思路,结合之前成功的项目,发现现在使用这个项目没有gradle的子模块,就尝试建了一个子模块:
在这里插入图片描述
然后就publish成功了:
在这里插入图片描述
github仓库中显示:
在这里插入图片描述
至此,使用gradle发布依赖包到github已经完全讲完了。

如何使用上传的依赖包

传都传上去了,总不能不说使用的事情吧,那不合理…
上面github截图那个红框点进去会看到:
在这里插入图片描述
如果不是很清楚怎么使用,就先看看这个,然后根据这个去在配置里引用该依赖包:
在这里插入图片描述
上面那块红框内的东西,跟publish时的配置保持一致就可以了,主要是url一定要一致。
dependencies里,引用依赖格式是groupId:artifactId:version
配置好以后按下面两种方式刷新都可以:
在这里插入图片描述

在这里插入图片描述
刷新之后在左侧也可查看。(如果下载不了,首先查看url以及dependencies到底设置的对不对,然后就是再次强调:网一定要好…不然很难下载下来。
在这里插入图片描述
到此结束吧,可能中途还会碰到一些问题,比如我在下载依赖包的时候,因为网络太差,导致下载失败解析不了,去本地仓库查看,发现目录下全是lastupdated后缀结尾的文件,于是整个目录全删除,网络确定好一点的时候,又重新刷新才下载下来。

官方文档(里面还有maven等各种型号):
https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-gradle-registry

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
依赖库通过 GitHub 导入可以分为两种情况: 1. 直接导入已经打包好的依赖库(jar、aar等) 2. 通过源码导入依赖库 下面分别介绍这两种情况的详细步骤。 ## 直接导入已经打包好的依赖库 1. 打开 GitHub 上要导入的依赖库的页面,找到 `Releases` 或 `Tags` 标签页。 2. 在 `Releases` 或 `Tags` 列表中找到你需要的版本。 3. 在需要的版本下找到你需要的文件,通常是以 `.jar` 或 `.aar` 结尾的文件。 4. 点击文件名进入文件详情页,找到 `Download` 按钮并点击下载。 5. 将下载的文件放到你的项目中,通常是放到 `libs` 目录下。 6. 在你的项目中找到 `build.gradle` 文件,在 `dependencies` 块中添加以下代码: ```groovy implementation files('libs/your_library_file.jar') // 或者 implementation files('libs/your_library_file.aar') ``` 7. 同步你的项目即可使用该依赖库。 ## 通过源码导入依赖库 1. 打开 GitHub 上要导入的依赖库的页面,找到 `Clone or download` 按钮并点击复制仓库地址。 2. 在你的项目中找到 `settings.gradle` 文件,在文件末尾添加以下代码: ```groovy include ':your_library_module' project(':your_library_module').projectDir = new File(settingsDir, '../your_library_folder') ``` 其中,`your_library_module` 是你将要导入的依赖库的模块名,`your_library_folder` 是你下载下来的依赖库源码文件夹的路径。 3. 在你的项目中找到 `build.gradle` 文件,在 `dependencies` 块中添加以下代码: ```groovy implementation project(':your_library_module') ``` 4. 同步你的项目即可使用该依赖库。 注意:如果导入的依赖库是一个 Android 库,你还需要在 `AndroidManifest.xml` 中添加以下代码: ```xml <application> <activity android:name="com.example.your_library.MainActivity" /> </application> ``` 其中,`com.example.your_library.MainActivity` 是你依赖库中的一个 Activity。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值