发布Android项目到MavenCentral踩坑记录

最近在折腾开源项目,在使用vanniktech/gradle-maven-publish-plugin发布到Maven Central Repository时遇到一些坑特别记录一下:

  • Cannot get stagingProfiles for account xxxx:是由于SONATYPE_HOST没设置正确导致的,来源

  • The key ID must be in a valid form (eg 00B5050F or 0x00B5050F), given value: :是由于keyId位数不正确,取最后8位即可。

  • 上传MavenCentral后提示dependency version information is missing: 使用BOM来依赖版本可能会导致这个问题, 指定具体版本来解决。

1. 创建Sonatype账号并获取token

central.sonatype.com/ 直接使用github登录即可, 这样可以直接认证github的namespace。到View Account → Generate User Token,生成token即可

2. 生成GPG签名

直接参考站内教程即可。 重点命令:

cmd 复制代码
//生成
gpg --gen-key
//上传
gpg --keyserver hkp://keyserver.ubuntu.com --send-keys 后8位ID
//验证
gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys 后8位ID
//导出
gpg -o E:/secring.gpg --export-secret-keys 后8位ID

3. 引入发布插件并配置文件

具体可以参考第二步的站内教程: 此处贴出正确的配置:

  • rootProject/gradle.properties 文件:
properties 复制代码
#------------------------------------------ publish config ----------------------------------------#
GROUP=io.github.ravenliao.htmlannotator
RELEASE_SIGNING_ENABLED=true
SONATYPE_HOST=CENTRAL_PORTAL
#
POM_NAME=HtmlAnnotator
POM_DESCRIPTION=Android HTML Rendering Library
POM_URL=https://github.com/RavenLiao/HtmlAnnotator
#
POM_SCM_URL=https://github.com/RavenLiao/HtmlAnnotator
POM_SCM_CONNECTION=https://github.com/RavenLiao/HtmlAnnotator.git
POM_SCM_DEV_CONNECTION=https://github.com/RavenLiao/HtmlAnnotator.git
#
POM_LICENCE_NAME=The Apache Software License, Version 2.0
POM_LICENCE_URL=https://www.apache.org/licenses/LICENSE-2.0.txt
POM_LICENCE_DIST=repo
#
POM_DEVELOPER_ID=RavenLiao
POM_DEVELOPER_NAME=RavenLiao
POM_DEVELOPER_URL=https://github.com/RavenLiao
  • 全局配置文件(~/.gradle/gradle.properties):
properties 复制代码
#publish
signing.keyId=GPG签名key后8位
signing.password=生成GPG签名的密码
signing.secretKeyRingFile=导出GPG签名的文件路径
mavenCentralUsername=第一步中生成的token的Username
mavenCentralPassword=第一步中生成的token的Password
相关推荐
alexhilton9 小时前
Compose中初始加载逻辑究竟应该放在哪里?
android·kotlin·android jetpack
zh_xuan9 小时前
启动RN服务端口被占用
android·react native
Code-keys11 小时前
Android Codec2 Filter 算法模块开发指南
android·算法·音视频·视频编解码
y = xⁿ13 小时前
MySQL:count(1)与count(*)有什么区别,深分页问题
android·数据库·mysql
程序员陆业聪14 小时前
Android启动全景图:一次冷启动背后到底发生了什么
android
安卓程序员_谢伟光16 小时前
m3颜色定义
android·compose
麻辣璐璐17 小时前
EditText属性运用之适配RTL语言和LTR语言的输入习惯
android·xml·java·开发语言·安卓
北京自在科技17 小时前
谷歌 Find Hub 网页端全面升级:电脑可直接管理追踪器与耳机
android·ios·安卓·findmy
Rush-Rabbit17 小时前
魅族21Pro刷ColorOS16.0操作步骤
android
爪洼传承人18 小时前
AI工具MCP的配置,慢sql优化
android·数据库·sql