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

发布一个自己的jar包给全球人使用

程序员文章站 2022-06-24 08:51:50
[TOC] maven 项目对于我们开发大大减少了我们的开始时间,提高了开发效率,那么如何开发出属于自己的一套maven项目了。今天来看看如何上传maven项目到*仓库

目录

maven 项目对于我们开发大大减少了我们的开始时间,提高了开发效率,那么如何开发出属于自己的一套maven项目了。今天来看看如何上传maven项目到*仓库

项目准备

  • 首先我们得创建一个maven项目;当然这里只是为了而是发布maven项目。没有maven的新建一个就行。有了自己maven项目,在这里就可以直接拿maven项目做测试。
    发布一个自己的jar包给全球人使用。至于项目的配置方面后面再说

sonatype

  • sonatype是一个通过nexus对开源项目提供托管服务的网站。你可以通过它发布项目的快照(snapshot)或者稳定版本(release)到maven*仓库。我们只需要注册一个sonatype的账号,新建一个issue,然后在项目的pom文件中进行配置即可。

注册

  • 这里注册的时候需要注意一下,用户名最好不要出现中文,这里中文注册没问题,但是后面发布到*仓库的时候会有麻烦。所以强烈建议这里用英文注册用户名。如果非要用中文注册也可以,只是在后面创建工单的时候需要注明一下新的username

发布一个自己的jar包给全球人使用

申请sonatype工单

  • 注册完成后进入首页开始创建。其中我们的groupid有一定的讲究。我们得拥有域的所有权。因为我们知道groupid默认是:com/org/cn + 域名 + 公司名 。比如我填写得是
    com.github.zxhtom,那么sonatype会要求你拥有github.com的所有权。因为github是开放性网站。另外zxhtom是我再github上的注册名。所有github.com/zxhtom这个地址就是属于我,所哟这样写就会验证通过。如果你有自己的域名zxhtom.com 。那么你的groupid就是是com.zxhtom.***

发布一个自己的jar包给全球人使用

发布一个自己的jar包给全球人使用

  • 注册完成之后系统不会自动跳转到我们新建的工单上。我们可以这样找到我们的工单

发布一个自己的jar包给全球人使用

  • 到这里我们的工单就申请完成了。如果你的条件和我上面说的一样。那么1~3小时审核就会通过的。现在我们就等着审核通过。这段时间我们可以进行下面的pgp和其他的配置
    我这里审核通过不到10分钟就通过了

发布一个自己的jar包给全球人使用

gpg配置


  • 安装最后我们最好也勾选一下安装gpg2.就在安装的界面上就可以勾选
  • 安装后我们打开cmd查看安装是否正常。
    发布一个自己的jar包给全球人使用

发布一个自己的jar包给全球人使用

  • 一切正常后我们开始生成秘钥。会生成私钥和公钥。我们需要将公钥上传到pgp官方服务器上。在2.0之前的版本中生成密钥的时候需要我们填写一些信息,我们不用填写一直回车就行。在real name 、email address、comment中我们需要填写我们的个人信息。这三项好像我们的个人介绍一样。因人而异。最后需要输入passphrase。相当于pgp的使用密码。这个很重要

发布一个自己的jar包给全球人使用

发布一个自己的jar包给全球人使用

  • 这些配置好会出现下面的画面说明配置成功
    发布一个自己的jar包给全球人使用

  • 最后我们通过下面的命令将公钥提交到服务器 (97f3f174是pub id ,pgp不同版本pub id 长度不一样。我们不用在意)
    gpg2 --keyserver hkp://pool.sks-keyservers.net --send-keys 97f3f174

项目配置

依赖oss-parent

  • 个人觉得这种方式不实用,因为我们平时开发maven不可能全都是那种没有parent的项目。又因为maven只能单继承。所以这种方式只能实现功能。但是不实用

自定义配置

pom配置

  • 里面就是一些上传是的验证,个人信息自己修改成自己的就行
<build>
      <plugins>
          <plugin>
              <groupid>org.apache.maven.plugins</groupid>
              <artifactid>maven-source-plugin</artifactid>
              <version>2.1.2</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.7</version>
              <executions>
                  <execution>
                      <id>attach-javadocs</id>
                      <goals>
                          <goal>jar</goal>
                      </goals>
                  </execution>
              </executions>
          </plugin>
          <plugin>
              <groupid>org.apache.maven.plugins</groupid>
              <artifactid>maven-gpg-plugin</artifactid>
              <version>1.1</version>
              <executions>
                  <execution>
                      <id>sign-artifacts</id>
                      <phase>verify</phase>
                      <goals>
                          <goal>sign</goal>
                      </goals>
                  </execution>
              </executions>
          </plugin>
      </plugins>
  </build>
  <licenses>
      <license>
          <name>the apache license, version 2.0</name>
          <url>http://www.apache.org/licenses/license-2.0.txt</url>
      </license>
  </licenses>
  <developers>
      <developer>
          <name>zxhtom</name>
          <email>870775401@qq.com</email>
          <roles>
              <role>developer</role>
          </roles>
          <timezone>+8</timezone>
      </developer>
  </developers>
  <scm>
      <connection>scm:git:https://github.com/zxhtom/bottom.git</connection>
      <developerconnection>scm:git:https://github.com/zxhtom/bottom.git</developerconnection>
      <url>https://github.com/zxhtom/bottom</url>
      <tag>${project.version}</tag>
  </scm>
  <distributionmanagement>
      <snapshotrepository>
          <id>ossrh</id>
          <url>https://oss.sonatype.org/content/repositories/snapshots</url>
      </snapshotrepository>
      <repository>
          <id>ossrh</id>
          <name>maven central staging repository</name>
          <url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
      </repository>
  </distributionmanagement>

全局settings配置

  • 然后我们只需要在maven的全局settings配置文件中配置我们的sonatype账号和pgp2的passphrase就行了。下面配置的password字段就是我们注册sonatype网站的密码。username是我们申请工单的时候填写的username,如果没有填写那么就是我们的用户名。
<!-- 前两个如果我们用的是继承oss-parent需要的。 -->
 <server>
    <id>sonatype-nexus-snapshots</id>
    <username>zxhtom</username>
    <password>*****</password>
  </server>
  <server>
    <id>sonatype-nexus-staging</id>
    <username>zxhtom</username>
    <password>******</password>
  </server>
  <!-- 下面这个使我们自定义用到的服务 -->
  <server>
    <id>ossrh</id>
    <username>zxhtom</username>
    <password>*****</password>
  </server>
  • 然后在新增一个profile
```

<profile>
      <id>ossrh</id>
      <activation>
        <activebydefault>true</activebydefault>
      </activation>
      <properties>
        <gpg.executable>gpg2</gpg.executable>
        <gpg.passphrase>*****</gpg.passphrase>
      </properties>
    </profile>
```

发布

mven clean deploy

效果
发布一个自己的jar包给全球人使用

  • 这里暂时在myeclipse中打包会出错。因为无法使用pgp,不知道什么原因。目前只能在cmd中打包。

验证

进入上方网站登录后进行查看我们是否发布的jar

发布一个自己的jar包给全球人使用

  • 这个时候我们就可以引用maven坐标使用了。但是目前在*仓库还是无法搜索的。需要等待几个小时才可以。