首先的你项目需要在Gitee
或者Github
上有仓库
我这里以Gitee
是的yhchat-sdk-core仓库为例
(资料图)
访问sonatype注册并登录
创建一个问题
填仓库名称
随意写写
填写自己的域名,如果没有域名的话,可以自行百度使用Gitee
、Github
的域名
需要根据项目的maven坐标按需填写,与maven项目pom配置一致
填仓库地址:https://gitee.com/daenmax/yhchat-sdk-core
填仓库Git地址:https://gitee.com/daenmax/yhchat-sdk-core.git
然后会有人审核你这个问题,全程跟进,稍等几分钟,就会有评论
需要验证组ID域名是否是你的,所以需要添加一条DNS TXT解析
OSSRH-92477
是你的问题编号,字母改成消息就是主机记录ossrh-92477
问题页面的地址栏网址就是记录值:https://issues.sonatype.org/browse/OSSRH-92477
解析添加好之后,一般过几分钟生效,
因为我这里已经点过了,所以没这个按钮了,具体就是 response
还是 完成
来着,我也忘了,点就行了
如果过几分钟后,状态或者解决结果 变成了:已解决,就代表验证通过了
去官网下载并安装:https://www.gpg4win.org/
弹窗提示就代表成功了
在settings.xml
里添加以下内容
ossrh sonatype账号 sonatype密码
如图
主要就是添加url
、licenses
、scm
、developers
、distributionManagement
等节点,具体参考下面我的完整POM文件
需要注意的是,plugins打包插件
建议使用和我一样的,或者你自己弄也行,打包时,必须同时打包出来源码
、文档
、jar
,否则后面的检查无法通过
另外需要注意的是,我们上传的远程仓库的地址是带s01前缀的,而比较旧的文章中不带s01前缀
这是因为旧的sonatype maven仓库已经资源满载了,所以官方新建了一个s01 maven仓库,未来可能还会有s02、s03
现阶段在sonatype JIRA管理平台上注册的用户,只能上传这个新的s01仓库
我的POM示例:
4.0.0 org.springframework.boot spring-boot-starter-parent 2.7.12 cn.daenx yhchat-sdk-core 1.0.0 yhchat-sdk-core yhchat-sdk-core是云湖社交的Java版本的SDK核心服务,通过此Core可以快速构建您的云湖机器人,能让您以非常便捷的方式和云湖服务进行交互。 https://gitee.com/daenmax/yhchat-sdk-core 1.8 2.7.12 5.8.19 org.springframework.boot spring-boot-starter true org.springframework.boot spring-boot-starter-web true org.springframework.boot spring-boot-starter-test test org.projectlombok lombok true cn.hutool hutool-all ${hutool.version} true org.apache.commons commons-lang3 true Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0.txt repo A business-friendly OSS license https://gitee.com/daenmax/yhchat-sdk-core.git git@gitee.com:daenmax/yhchat-sdk-core.git https://gitee.com/daenmax/yhchat-sdk-core DaenMax DaenMax 1330166565@qq.com Developer +8 ossrh https://s01.oss.sonatype.org/content/repositories/snapshots ossrh https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/ org.apache.maven.plugins maven-surefire-plugin 2.17 true org.apache.maven.plugins maven-compiler-plugin 3.10.1 1.8 org.apache.maven.plugins maven-source-plugin attach-sources jar org.apache.maven.plugins maven-gpg-plugin 1.6 verify sign org.apache.maven.plugins maven-release-plugin 2.5.1 true false release deploy org.apache.maven.plugins maven-javadoc-plugin 2.9.1 attach-javadocs jar -Xdoclint:none
需要注意以下几点:
1.环境变量里的JDK版本需要和你项目使用的JDK版本一致
2.不要使用IDEA的打包,需要使用CMD命令打包
在项目根目录打开CMD
执行打包命令
mvn clean install deploy -P release
然后会弹出一个框框,然你输入秘钥,这个就是上面说的这个密码一定要记住
如果成功的话,就代表成功了(好像有点废话)
上面maven命令执行完,我们还需要进行进一步的操作这是因为我们上传的jar放入了staging暂存库里面,我们需要把它转到release库
这其中sonatype平台会针对你的项目信息、jar文档、源码等内容进行完整性校验
完整性校验不通过的项目是无法转到release的,也就无法同步到maven中央仓库
暂存库登录地址:https://s01.oss.sonatype.org/#stagingRepositories
账号密码和sonatype一样
登录上来后,点击Refresh
,就可以看到你刚刚上传的了
如果认为刚刚打包上传错了,那就点击Drop
删除,然后重新执行maven打包上传命令
觉得无误后,点击Close
,sonatype就会开始扫描和检查你的项目了,
如果检查通过,就点击Release
开始发行了,发行成功后,就可以点击Drop
删除
如果检查不通过,就点击下面的Summary
和Activity
来查看为啥不通过
至此,就完事了,在 Maven Central 可以立即进行搜索到
而 Maven Repository大概第二天才能搜索到
(在此期间,无法搜索到也不影响项目中使用坐标引用你的项目)
一切都ok之后,回到Sonatype JIRA管理平台将“问题”关闭,至此,恭喜你~
Copyright © 2015-2022 人人快报网版权所有 备案号:粤ICP备18023326号-36 联系邮箱:8557298@qq.com