issues.sonatype.org/secure/Sign… php
issues.sonatype.org/secure/Dash… html
进来以后以下: java
issues.sonatype.org/secure/Crea…git
My issue : issues.sonatype.org/browse/OSSR…github
Status状态从OPEN变成RESOLVED表示成功!apache
将jar包上传到这里,Release 以后就会同步到maven中央仓库ubuntu
注:发布到Maven仓库中的全部文件都要使用GPG签名,以保障完整性。安全
Windows系统下载地址: www.gpg4win.org/download.ht…bash
安装很简单,以下: 服务器
gpg --version
复制代码
cmd执行以下命令:
gpg --gen-key
复制代码
【注】输入的 Passphrase 值至关于密钥的密码,后面会用到!!
目的:将公钥上传到公共的密钥服务器(也就是上传到第三方的key验证库)让其余人能够经过公钥来验证jar包的完整性
查看公钥
gpg --list-keys
复制代码
其中3408AAAFEE3AB847DE82602B448854BCFF61E7F7为公钥ID
gpg --keyserver hkp://pool.sks-keyservers.net --send-keys 公钥ID或上面提到的key
gpg --keyserver hkp://keyserver.ubuntu.com:11371 --send-keys 公钥ID或上面提到的key
复制代码
查询公钥是否发布成功
gpg --keyserver hkp://pool.sks-keyservers.net --recv-keys 公钥ID或上面提到的key
gpg --keyserver hkp://keyserver.ubuntu.com:11371 --recv-keys 公钥ID或上面提到的key
复制代码
<servers>
<!-- 上传jar包到maven中央仓库配置start -->
<server>
<id>ossrh</id>
<username>Sonatype帐号</username>
<password>Sonatype密码</password>
</server>
<!-- 上传jar包到maven中央仓库配置end -->
</servers>
复制代码
可参考Sonatype提供的要求: central.sonatype.org/pages/requi… Sonatype提供的pom文件demo:github.com/simpligilit…
个人pom文件配置以下:github.com/zhengqingya…
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.github.zhengqing</groupId>
<artifactId>OSSRH-49683</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>${project.groupId}:${project.artifactId}</name>
<description>The test uploads the jar to the maven central repository</description>
<url>https://github.com/zhengqingya/OSSRH-49683</url>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<maven.compiler.source>${java.version}</maven.compiler.source>
<maven.compiler.target>${java.version}</maven.compiler.target>
<maven.deploy.skip>true</maven.deploy.skip>
</properties>
<dependencies>
<!-- ... -->
</dependencies>
<!-- 许可证信息 -->
<licenses>
<!-- Apache许可证 -->
<license>
<name>The Apache Software License, Version 2.0</name>
<url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
</license>
<!-- MIT许可证 -->
<!-- <license> <name>MIT License</name> <url>http://www.opensource.org/licenses/mit-license.php</url> </license>-->
</licenses>
<!-- SCM信息 -> git在github上托管 -->
<scm>
<connection>scm:git:git://github.com/zhengqingya/OSSRH-49683.git</connection>
<developerConnection>scm:git:ssh://github.com/zhengqingya/OSSRH-49683.git</developerConnection>
<url>https://github.com/zhengqingya/OSSRH-49683/tree/master</url>
</scm>
<!-- 开发者信息 -->
<developers>
<developer>
<name>zhengqingya</name>
<email>960869719@qq.com</email>
<url>https://github.com/zhengqingya</url>
</developer>
</developers>
<!-- 使用我的资料:因为生成javadoc和源jar以及使用GPG签署组件是一个至关耗时的过程,所以这些执行一般与正常的构建配置隔离并移动到配置文件中。而后,在经过激活配置文件执行部署时,将使用此配置文件。 -->
<profiles>
<profile>
<id>ossrh</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<build>
<plugins>
<!-- 要生成Javadoc和Source jar文件,您必须配置javadoc和源Maven插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>2.2.1</version>
<executions>
<execution>
<id>attach-sources</id>
<goals>
<goal>jar-no-fork</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-javadoc-plugin</artifactId>
<version>2.9.1</version>
<executions>
<execution>
<id>attach-javadocs</id>
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
</plugin>
<!-- 必须配置GPG插件用于使用如下配置对组件进行签名 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-gpg-plugin</artifactId>
<version>1.5</version>
<executions>
<execution>
<id>sign-artifacts</id>
<phase>verify</phase>
<goals>
<goal>sign</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<!-- 【注】snapshotRepository 与 repository 中的 id 必定要与 setting.xml 中 server 的 id 保持一致! -->
<distributionManagement>
<snapshotRepository>
<id>ossrh</id>
<url>https://oss.sonatype.org/content/repositories/snapshots</url>
</snapshotRepository>
<repository>
<id>ossrh</id>
<url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
</repository>
</distributionManagement>
</profile>
</profiles>
</project>
复制代码
部署命令以下:
mvn clean deploy
复制代码
当咱们的项目中含有多个模块时,咱们可使用 -projects 来指定部署哪个模块
举例:
mvn clean deploy -projects demo
复制代码
mvn clean deploy -projects demo,demo2
复制代码
【注】第一次执行时须要输入以前设置的passphrase密码 ~
若是不想出现此,也可在一开始直接执行以下命令:
mvn clean deploy -P sonatype-oss-release -Darguments="gpg.passphrase=设置gpg密钥时输入的Passphrase"
若是出现上传问题,能够尝试将 oss.sonatype.org/#stagingRep… 上以前上传的错误项目所有删除【选中点击Drop便可删除】,而后再次上传~
最后成功以下:
到 oss.sonatype.org/#stagingRep… 中勾选本身上传的构件(咱们的jar包上传到这里哦)点击Close而后再Release,Release以后就会同步到maven中央仓库
最终到 maven中央仓库 中就能够搜索到了