欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-07-06 11:30:15
目录一、注册sonatype账号申请创建项目二、等待sonatype申请批复三、生成gpg五、sonatype将项目同步至maven*仓库一、注册sonatype账号申请创建项目到链接:注册一个账号...

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

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

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

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

二、等待sonatype申请批复

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

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

三、生成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.srcdirs = ["src/main/java","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,使用第一步注册的账号密码登陆。

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

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

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