做java 开发那当然离不开jar包管理, 不知何时一向想想封装一个自己的jar 然后发布到maven中心库房给他人运用。

hhh 我感觉自己写一个jar包东西然后,被很多人运用是一件很牛,很快乐作业。

总算有了这个机会,和时刻。SpringBoot stater出来了 依据场景启动器你能够轻松定义自己的stater组件,然后甚至,能够发布到maven库房。供大家运用。

我总结,写了一个作为我作业多年程序员,自己东西类库,stater。

一键搞定发布自己Jar到Maven中央仓库

Github地址

依据它,你能够轻松开发SpringBoot WEB API,进步功率。不在去关心一些繁琐。重复作业,而是把要点聚焦到事务。

回到正题,这篇文章依据我这个,stater讲一下。怎么把自己定义stater 发布到maven中心库房。

注册 sonatype账号

进入 issues.sonatype.org 注册自己的账号,依据这个渠道,快速发布到maven库房

注册完结后记住,账号暗码,后边发布需求运用授权

一键搞定发布自己Jar到Maven中央仓库

创立自己的maven项目工单

注册完结后咱们创立自己,发布的maven项目,点击新建

一键搞定发布自己Jar到Maven中央仓库

项目挑选:Community Support – Open Source Project Repository Hosting (OSSRH)

问题类型挑选:New Project

一键搞定发布自己Jar到Maven中央仓库

*的是必填项,其他留空或许保持默许即可,然后新建工单等候管理员审阅

项目地址填一个你的项目的Github库房地址。这儿还是着重一下组id的填写,组id需求依据你自己的域名或许开源库房地址来填。

后边在问题-我的陈述中能够追寻issue的审阅状况

一键搞定发布自己Jar到Maven中央仓库

等候管理员审阅。审阅完结,管理员会在下面提示你让你验证这个域名是你的或许证明gitee或许github空间是你的

关闭maven工单项目

maven工单项目审阅通往后,会有邮件提示。

新建成功issue后需求等候Sonatype的作业人员进行审阅,审阅时刻大约几分钟左右(我其时5min貌似有人几小时的….),审阅通往后issue的Status会转变为Resolved,此刻你就能够进行下一步操作了

你点击问题—找到你自己新建的项目

一键搞定发布自己Jar到Maven中央仓库

然后点击Respond按钮开启工单,让管理员去验证。

一键搞定发布自己Jar到Maven中央仓库

等候验证完结,管理员就会接着回复你验证成功,这就阐明你的工单经过了,能够上传项目了

假如是用域名,则管理员会让你给你的域名添加一个TXT解析,然后他来验证:

一键搞定发布自己Jar到Maven中央仓库

没问题,这个时分能够关闭问题

一键搞定发布自己Jar到Maven中央仓库

项目装备

maven 装备

在你maven装备文件中装备你注册issues.sonatype.org账号暗码

在maven 的conf文件夹下settings.xml 文件的servers节点装备如下

 <server>
      <id>snapshots</id>
      <username>kenx</username>
      <password>xxxx</password>
    </server>
    <server>
      <id>releases</id>
      <username>kenx</username>
      <password>xxxx</password>
    </server>
    <server>
      <id>ossrh</id>
      <username>kenx</username>
      <password>xxx</password>
    </server>

秘钥装备

运用gpg生成秘钥

上传项目需求秘钥签名认证。本地需求生成暗码。而且把公钥上传服务。

生成秘钥

gpg --gen-key

运转后gpg要求你挑选加密算法,过期时刻等等,这些直接挑选默许值即可。经过对比发现,gpg 2.0以上的版本运转gpg –gen-key指令 会跳过这些过程。

之后gpg要求你输入名字,邮箱以及要害的Passphrase(这个暗码要自己记住,后边有用),依次输入即可。然后gpg为你生成了一对秘钥。

检查秘钥

gpg --list-keys

一键搞定发布自己Jar到Maven中央仓库

在pub字段下面有一个十六进制数,那就是这个秘钥的ID

然后咱们要把这个秘钥上传至公钥服务器,运用如下指令:

gpg --keyserver keyserver.ubuntu.com --send-keys 秘钥ID

验证是否成功地上传到了服务器:

gpg --keyserver keyserver.ubuntu.com --recv-keys 秘钥ID

假如两条指令执行输出成果都如下阐明成功:

一键搞定发布自己Jar到Maven中央仓库

这样,就完结了秘钥的装备了。

修正项目pom装备

接下来咱们需求装备咱们项目中pom 文件,

<groupId>cn.soboys</groupId>
    <artifactId>rest-api-spring-boot-starter</artifactId>
    <version>1.3.0</version>
    <packaging>jar</packaging>
    <name>rest-api-spring-boot-starter</name>
    <description>SpringBoot Easy Fast Rest WEB 进步SpringBoot Web开发作业功率 RestFull API运用 大局过错拦截,参数校验, 过错国际化 ,自定义过错呼应 ,事务反常断言 ,Redis 东西库运用 ,RestTemplate 请求东西 ,日志运用 ,集成mybatisPlus一键代码生成</description>
    <url>https://github.com/coder-amiao/rest-api-spring-boot-starter</url>
    <!-- 项目设定 -->
    <properties>
        <java.version>1.8</java.version>
        <maven.compiler.source>${java.version}</maven.compiler.source>
        <maven.compiler.target>${java.version}</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <gpg.passphrase>1234qwer</gpg.passphrase>
        <gpg.keyname>E933FBC878FB2EC0900A2ABAF79C3CD9E9E6A8EF</gpg.keyname>
        <gpg.homedir>/Users/xiangyong/.gnupg</gpg.homedir>
    </properties>
    <!-- 许可证信息,这儿是Apache 2.0的许可证,大家依据实际状况修正 -->
    <licenses>
        <license>
            <name>The Apache Software License, Version2.0</name>
            <url>https://www.apache.org/licenses/</url>
            <distribution>repo</distribution>
        </license>
    </licenses>
    <!--   开发人员信息         -->
    <developers>
        <developer>
            <name>三时</name>
            <email>xymarcus@163.com</email>
        </developer>
    </developers>
    <!--   项目库房信息         -->
    <scm>
        <connection>scm:git:https://github.com/zw201913/jtile38.git</connection>
        <developerConnection>https://github.com/coder-amiao/rest-api-spring-boot-starter</developerConnection>
        <url>https://github.com/coder-amiao/rest-api-spring-boot-starter.git</url>
        <tag>v${project.version}</tag>
    </scm>
    <!-- 中心库房地址装备,不需求修正 -->
    <distributionManagement>
        <snapshotRepository>
            <id>ossrh</id>
            <url>https://s01.oss.sonatype.org/content/repositories/snapshots</url>
        </snapshotRepository>
        <repository>
            <id>ossrh</id>
            <url>https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/</url>
        </repository>
    </distributionManagement>
<build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <!-- Source -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-source-plugin</artifactId>
                <version>2.2.1</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>jar-no-fork</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
            <!-- Javadoc东西 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-javadoc-plugin</artifactId>
                <version>2.10.4</version>
                <configuration>
                    <additionalJOptions>
                        <additionalJOption>-Xdoclint:none</additionalJOption>
                    </additionalJOptions>
                </configuration>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>jar</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
            <!-- GPG -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-gpg-plugin</artifactId>
                <version>1.6</version>
                <configuration>
                    <gpgArguments>
                        <arg>--pinentry-mode</arg>
                        <arg>loopback</arg>
                    </gpgArguments>
                </configuration>
                <executions>
                    <execution>
                        <id>sign-artifacts</id>
                        <phase>verify</phase>
                        <goals>
                            <goal>sign</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

注意装备的groupId, 有必要和你之前创立的maven项目工单保持一致

pom.xml 中有必要包括:name、description、url、licenses、developers、scm 等基本信息,运用了 Maven 的 profile 功能,只有在 release 的时分,创立源码包、文档包、运用 GPG 进行数字签名。

此外,snapshotRepository 与 repository 中的 id 必定要与 setting.xml 中 server 的 id 保持一致。

假如是多模块项目的话,只需求在父 pom.xml 中声明这些,子 pom.xml 中只需求修正相应的一些信息,如 name 标签。

项目发布

接下来你能够运用deploy 发布项目

一键搞定发布自己Jar到Maven中央仓库

或许指令

mvn clean deploy

发布项目到中心库房

上面的过程只是把项目传到了Sonatype上了,还没有发布出去。

进入s01.oss.sonatype.org,登录,账号是之前注册账号用户名和暗码

点击周围的Staging Repositories即可看到咱们发布的项目。

一键搞定发布自己Jar到Maven中央仓库

勾选项目,点击close按钮,开始进行项目校验。

一键搞定发布自己Jar到Maven中央仓库

再点击下面的active标签能够检查close的进展:

一键搞定发布自己Jar到Maven中央仓库

显示All rules passed: Central Sync Requirement就阐明校验经过,能够发布了。

假如过程正按钮是灰色,或许不能点击,重复刷新等候就行(有可能是网络等其他原因)。然后重复上面过程。即可

再点击上面的release按钮即可发布到中心库房了。

完结后,大约过个2个小时,你就能够在search.maven.org找到你的发布的项目了!

总结概括

以后发布项目,假如groupId不变的话,咱们就不需求再去请求工单了。

直接重复上述的二、三、四步中的部分要害过程即可。

上述settings.xml现已装备了servers,

就不必再次装备了,即第二步装备settings.xml能够省略了。秘钥也现已生成过了,也不需求再次生成了, 即第三步的秘钥生成也不需求了。不过假如更换了电脑,那就要重新装备settings.xml偏重新生成并上传秘钥了。

关注公众号,程序员三时 持续输出优质内容 期望给你带来一点启示和帮助