我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用gradle将java项目推送至maven中央仓库

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用gradle将java项目推送至maven中央仓库

一、注册Sonatype账号申请创建项目

到链接:https://issues.sonatype.org/注册一个账号。
创建点击顶部导航栏的 create 创建项目

在这里插入图片描述

如上填写,注意的是group id我这里使用的是gitee的二级域名地址,这个域名必须是真实的,与project url中的一致。或者自己有一个域名按照提示的链接去验证。project url是代码地址,我这里使用的gitee的地址,scm url是代码仓库地址。

二、等待Sonatype申请批复

等待批复结果,如果有问题,按照提示修改,这是我的ISSUE

在这里插入图片描述

三、生成GPG

从地址https://gpg4win.org/thanks-for-download.html下载,我使用的windows版本。

执行 gpg --gen-key
按照提示的信息填入密码,用户名等信息,这些信息记录下来。这里填入的密码就是上面

执行gpg --list-keys 可以看到


pub   2048R/B98765 2018-12-08
uid                  
sub 2048R/A123456 

第一行便是对应的公钥文件位置,B98765便是public key Id,这个id也就是上面

执行


 gpg --keyserver hkp://pool.sks-keyservers.net --recv-keys B98765

将公钥发送到
hkp://pool.sks-keyservers.net

导出key:
gpg --export-secret-key 2048R/B98765 > secret.gpg

四、配置gradle

注释下面的url中有s01,必须使用https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/,网上教程中的都没有s01,那是过时的教程。
gradle中添加插件:


apply plugin: 'maven-publish'
apply plugin: 'signing'

推送配置:


    jar {
        enabled = true
    }
    task sourcesJar(type: Jar) {
        from sourceSets.main.allJava
        archiveClassifier = 'sources'
    }
    task javadocJar(type: Jar) {
        from javadoc
        classifier = 'javadoc'
    }
    sourceSets.main.resources.class="lazy" data-srcDirs = ["class="lazy" data-src/main/java","class="lazy" data-src/main/resources"]


    publishing {
        publications {
            mavenJava(MavenPublication) {
                groupId project.group
                artifactId project.name
                version project.version
                //若是war包,就写components.web,若是jar包,就写components.java
                from components.java
//                artifact shadowJar
                artifact sourcesJar
                artifact javadocJar
                pom {
                    // 构件名称
                    // 区别于artifactId,可以理解为artifactName
                    name = 'newframe'
                    // 构件描述
                    description = 'newframe快速开发框架'
                    // 构件主页
                    url = 'https://gitee.com/quanwenz/newframe'
                    // 许可证名称和地址
                    licenses {
                        license {
                            name = 'The Apache License, Version 2.0'
                            url = 'http://www.apache.org/licenses/LICENSE-2.0.txt'
                        }
                    }
                    // 开发者信息
                    developers {
                        developer {
                            name = 'iscas'
                            email = 'quanwen@iscas.ac.cn'
                        }
                    }
                    // 版本控制仓库地址
                    scm {
                        url = 'https://gitee.com/quanwenz/newframe'
                        connection = 'scm:git:https://gitee.com/quanwenz/newframe.git'
                        developerConnection = 'scm:git:https://gitee.com/quanwenz/newframe.git'
                    }
                }
            }
        }
        // 定义发布到哪里
        repositories {
            maven {
                name 'newframeRepository'
//                url "https://oss.sonatype.org/service/local/staging/deploy/maven2"
                url "https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/"
                credentials {
                    // 这里就是之前在issues.sonatype.org注册的账号
                    username = "${sonatypeUsername}"
                    password = "${sonatypePassword}"
                }
            }
        }
    }

    signing {
        sign publishing.publications.mavenJava
    }

    javadoc {
        // <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        // 防止本地打开中文乱码
//        options.addStringOption("charset", "UTF-8")
        options.encoding = "UTF-8"
        failOnError = false
    }
}

在项目下添加gradle.properties目录
添加配置:


signing.keyId=ABC2E7F0
signing.password=xxx
signing.secretKeyRingFile=C:/Users/admin/secret.gpg

sonatypeUsername=zhuquanwen
sonatypePassword=xxxx

其中keyId是gpg那步生成keyid,密码为生成时填入的密码,secretKeyRingFile是导出的文件,
sonatypeUsername和sonatypePassword是第一步注册的账号和密码

在gradle的task中添加publish将代码上传至中央仓库

五、Sonatype将项目同步至Maven中央仓库

登陆https://s01.oss.sonatype.org/#stagingRepositories,使用第一步注册的账号密码登陆。

在这里插入图片描述

选中仓库,先点击close,再执行release,等待4个小时就可以了

到此这篇关于如何使用gradle将java项目推送至maven中央仓库的文章就介绍到这了,更多相关gradle推送至maven中央仓库内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何使用gradle将java项目推送至maven中央仓库

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录