国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

發(fā)布jar包到maven中央倉庫

這篇具有很好參考價值的文章主要介紹了發(fā)布jar包到maven中央倉庫。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

1. 環(huán)境

在網(wǎng)上找的很多文章中寫得都有很多問題,這里記錄一下最近一次成功地發(fā)布jar包到maven中央倉庫的過程。并附帶上每一個步驟官方的指導鏈接。

  • 系統(tǒng):mac(windows系統(tǒng)在下載輔助工具時不太一樣,在配置上和mac系統(tǒng)沒有區(qū)別)
  • IDE:IntelliJ IDEA
  • JDK:1.8
  • maven:3.8.1(IDEA自帶的版本)
  • 代碼:上傳到github上(使用gitee也行)
  • 發(fā)布形式:以jar包發(fā)布release版本(非SNAPSHOT版本)

2. 項目配置

官方對發(fā)布的項目做了一些必需的要求,如果不按要求來,發(fā)布可能會報錯。

2.1. javadoc和source

以非pom方式打包的項目(pom.xml配置文件中可以通過

標簽配置打包方式,默認就是jar),在打包完成后,target目錄下必須要包含***-sources.jar***-javadoc.jar。如下圖:
發(fā)布jar包到maven中央倉庫
為了達成以上效果,需要在pom.xml中依賴兩個插件:

<build>
    <plugins>
        <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>
    </plugins>
</build>

參考:https://central.sonatype.org/publish/requirements/#supply-javadoc-and-sources

2.2. 使用 GPG/PGP 簽署文件

打包完成后,target目錄下必須要包含***.jar.sac。如下圖:
發(fā)布jar包到maven中央倉庫
為了達成以上效果,需要在pom.xml中依賴插件(加完插件不要急著構建,還要下載GPG生成密鑰,后面會說):

<build>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-gpg-plugin</artifactId>
        <version>3.1.0</version>
        <executions>
            <execution>
                <id>sign-artifacts</id>
                <phase>verify</phase>
                <goals>
                    <goal>sign</goal>
                </goals>
            </execution>
        </executions>
    </plugin>
</build>

參考:https://central.sonatype.org/publish/requirements/#sign-files-with-gpgpgp

2.3. 項目名稱和版本配置

  • groupId:使用正確的反向域名。如果有私人域名,可以配置成私人域名(后面配置起來比較麻煩)。如果沒有私人域名,可以直接使用github的域名:io.github.{account}(gitee同理,推薦使用這種方式, account是github注冊的登錄賬號)。
  • artifactId:項目名稱,可以隨意發(fā)揮。
  • version:版本,可以使用1.1.1這種格式,不推薦帶-SNAPSHOT,快照版本不會直接發(fā)布到中央倉庫。
發(fā)布jar包到maven中央倉庫

參考:https://central.sonatype.org/publish/requirements/#correct-coordinates

2.4. 項目名稱、描述和 URL

這個是為了增加可讀性。

  • name:推薦使用這種格式:<name>${project.groupId}:${project.artifactId}</name>,當然也可以自定義。
  • description:項目描述,自己發(fā)揮。
  • url:項目地址,直接使用github(或gitee)上項目的地址即可。
發(fā)布jar包到maven中央倉庫

參考:https://central.sonatype.org/publish/requirements/#project-name-description-and-url

2.5. 許可證書

可以使用Apache/MIT的許可證書,直接拷貝下面的即可:

<licenses>
        <license>
        <name>The Apache Software License, Version 2.0</name>
        <url>https://www.apache.org/licenses/LICENSE-2.0.txt</url>
    </license>
</licenses>

參考:https://central.sonatype.org/publish/requirements/#license-information

2.6. 開發(fā)人員信息

留你自己的藝名和郵箱:

<developers>
        <developer>
        <name>你的藝名</name>
        <email>你的郵箱</email>
    </developer>
</developers>

參考:https://central.sonatype.org/publish/requirements/#developer-information

2.7. SCM 源碼管理系統(tǒng)信息

可以使用github(或gitee)的項目地址。

<scm>
    <connection>scm:git:git://github.com:maidoubaobao/easy-tool.git</connection>
    <developerConnection>scm:git:ssh://github.com:maidoubaobao/easy-tool.git</developerConnection>
    <url>https://github.com/maidoubaobao/easy-tool/tree/master</url>
</scm>

參考:https://central.sonatype.org/publish/requirements/#scm-information

2.8. 文件簽名校驗(非必需)

官網(wǎng)說必需要包含.md5.sha1簽名校驗文件,但我沒有特地去配置這個,也是可以發(fā)布的??梢蕴^這一步。

參考:https://central.sonatype.org/publish/requirements/#provide-files-checksums

3. 在 JIRA 上提發(fā)布申請

3.1. 注冊 JIRA

點擊如下鏈接注冊賬號并登錄,如果有賬號直接登錄即可:
https://issues.sonatype.org/secure/Signup!default.jspa

參考:https://central.sonatype.org/publish/publish-guide/#initial-setup

3.2. 創(chuàng)建項目

點擊新建,按照下面的圖示來填寫:
發(fā)布jar包到maven中央倉庫
發(fā)布jar包到maven中央倉庫

  • groupId:要和項目里對應上,必須是一個可用的域名的反轉字符串,如果項目是放在github上,必須使用io.github.{account}的格式,否則會審核不通過(注意:不能使用com.github)。
  • Project URL/SCM url:直接使用github的項目地址即可。

3.3. 查看剛剛創(chuàng)建的項目

正常情況下創(chuàng)建好默認就會進入剛剛創(chuàng)建的項目,如果進不去,可以按照路徑項目-查看所有項目-類別-Central即可看到項目鏈接,點進去后,切換篩選器我的報告就能看到創(chuàng)建的項目了。
發(fā)布jar包到maven中央倉庫
發(fā)布jar包到maven中央倉庫

3.4. 在github中創(chuàng)建一個空項目

創(chuàng)建好的項目,會分配一個唯一標識OSSRH-***(見上圖),需要用這個標識去github上創(chuàng)建一個空項目,這個是為了向核審管理員證明需要發(fā)布的github項目確實是你自己的項目。
發(fā)布jar包到maven中央倉庫

3.5. 等待管理員審核

管理員都在國外,因為時差,一般隔天才會核審通過。沒辦法,耐心等著吧。
審核通過后,會發(fā)郵件(郵箱就是注冊JIRA的那個),也會在JIRA項目下出現(xiàn)活動日志。
發(fā)布jar包到maven中央倉庫

4. 獲取 GPG 密鑰

在等待JIRA項目審核的同時,可以并行把GPG密鑰搞定。
注意:mac系統(tǒng)和windows系統(tǒng)在獲取GPG密鑰時有些區(qū)別,mac全程都是通過命令行搞定的,而windows提供了操作界面,可能會方便一點。這里只介紹mac系統(tǒng)的配置方式,windows系統(tǒng)可以自行搜配置教程。

4.1. 安裝 GnuPG

  • 用下面的鏈接下載 GnuPG,選擇系統(tǒng)對應的版本。

https://gnupg.org/download/index.html#sec-1-2
發(fā)布jar包到maven中央倉庫
發(fā)布jar包到maven中央倉庫

  • 驗證安裝是否成功

使用gpg --version命令來驗證,如果輸出了版本則說明安裝成功。
發(fā)布jar包到maven中央倉庫

參考:https://central.sonatype.org/publish/requirements/gpg/#installing-gnupg

4.2. 生成密鑰對

使用命令gpg --full-generate-key生成密鑰對,2年內有效。執(zhí)行命令后,需要輸入姓名和郵箱(建議和注冊JIRA時用的一致),然后輸入o(注意是字母o)確認生成。隨后會提示輸入一個passphrase口令來保護你的密鑰對,這個口令要記住,后面配置需要使用。
注意:這個命令不建議執(zhí)行多次,不然生成了多個密鑰對,發(fā)布時還要去配置使用哪個密鑰對,比較麻煩。
發(fā)布jar包到maven中央倉庫

參考:https://central.sonatype.org/publish/requirements/gpg/#generating-a-key-pair

4.3. 發(fā)布公鑰

  • 使用命令gpg --keyserver pgp.mit.edu --send-keys 公鑰來發(fā)布。

官網(wǎng)提供了3個地址,有的地址可能不能用,上面這個地址親測有效。(所以官方也不一定靠譜)

發(fā)布jar包到maven中央倉庫
  • 使用命令gpg --keyserver pgp.mit.edu --recv-keys 公鑰驗證是否發(fā)布成功。

注意:驗證的命令要等一會執(zhí)行才能響應數(shù)據(jù),估計發(fā)布可能有點延時,可以多執(zhí)行幾次。反正如果響應如圖所示,就代表發(fā)布成功了。
發(fā)布jar包到maven中央倉庫

參考:https://central.sonatype.org/publish/requirements/gpg/#distributing-your-public-key

5. JIRA 項目核審通過后的配置

5.1. 倉庫地址

核審通過后,在JIRA上的項目里可以看到日志,這代表項目已經(jīng)擁有發(fā)布權限了。下圖標記出來的就是倉庫地址。
發(fā)布jar包到maven中央倉庫

5.2. 修改 maven 配置

這里修改的是mavensetting.xml配置文件,如果不知道配置文件在哪里(那么你不是一個合格的程序猿),可以在IntelliJ IDEAsettings > Build,Execution,Deployment > Builds Tools > Maven頁面找到User settings file。

  • 配置JIRA賬戶用于發(fā)布
    這里的<server>-<id>是有用的,一會要在項目的pom文件配置中要對應上。
<servers>
    <server>
        <id>ossrh</id>
        <username>JIRA用戶名</username>
        <password>JIRA登錄密碼</password>
    </server>
</servers>
  • 配置GPG用于文件簽署校驗
    前文2.2小節(jié)已經(jīng)在項目中配置了GPG插件了,這里要配置GPG的口令才能進行正常的簽署。
    前文4.2小節(jié)生成GPG密鑰對的時候,輸入過一個口令passphrase,就用那個。
<profiles>
    <profile>
        <id>ossrh</id>
        <activation>
            <activeByDefault>true</activeByDefault>
        </activation>
        <properties>
            <gpg.executable>gpg2</gpg.executable>
            <gpg.passphrase>GPG口令</gpg.passphrase>
        </properties>
    </profile>
</profiles>

5.3. 配置倉庫地址和插件

這里是在項目的pom文件中配置。

  • 配置發(fā)布的倉庫地址
    這里的倉庫域名,可以從JIRA項目的日志里看到,核審通過后會給你一個地址,就用那個做為域名。按照下面的格式來配:
<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>
  • 配置倉庫插件
    這里的serverId要和前面maven配置文件setting.xml中配置的<server>-<id>保持一致。nexusUrl就是倉庫地址,和上面配置的一樣。
<build>
    <plugins>
        <plugin>
            <groupId>org.sonatype.plugins</groupId>
            <artifactId>nexus-staging-maven-plugin</artifactId>
            <version>1.6.13</version>
            <extensions>true</extensions>
            <configuration>
                <serverId>ossrh</serverId>
                <nexusUrl>https://s01.oss.sonatype.org/</nexusUrl>
                <autoReleaseAfterClose>true</autoReleaseAfterClose>
            </configuration>
        </plugin>
    </plugins>
</build>

6. 發(fā)布

JIRA 核審通過后,就可以發(fā)布了

6.1. 發(fā)布到中央倉庫

  • 可以直接在IntelliJ IDEA中點擊deploy來發(fā)布:
發(fā)布jar包到maven中央倉庫
  • 輸出如下結果說明發(fā)布成功了:
發(fā)布jar包到maven中央倉庫

6.2. 驗證發(fā)布結果

發(fā)布成功以后,并不能立刻在maven中央倉庫中搜索到,大概隔一天以后才能搜索得到,所以不要心急,耐心等待。

  • JIRA 上的回應

執(zhí)行完發(fā)布動作以后,大概隔了幾分鐘以后,JIRA項目下會多出一條日志:
發(fā)布jar包到maven中央倉庫
這條日志給出了兩個地址和兩個時間,反正差不多要等個那么長的時間才能搜得到。我已經(jīng)發(fā)布到中央倉庫里了,第一個地址里還是找不到,但是第二個地址里能搜到:
發(fā)布jar包到maven中央倉庫
下面這個地址好像是執(zhí)行完發(fā)布操作后,過一會就能搜得到,可以試試:
https://s01.oss.sonatype.org/content/groups/public/

  • 在中央倉庫里搜索

一般是隔天,才能在中央倉庫里搜得到,在阿里云的倉庫里也可以搜得到,阿里云本來就是從中央倉庫同步的。

建議使用groupId來搜,一搜一個準。用artifactId來搜在第一頁可能找不到,因為maven會對搜索結果做排序。
發(fā)布jar包到maven中央倉庫

7. 彩蛋

  • JAVA_HOME 報錯

如果遇到這樣的報錯The environment variable JAVA_HOME is not correctly set,不要慌,一般是因為你本地環(huán)境變量沒有設置JAVA_HOME或者設置成了jre的目錄。如果是因為前者可以去設置一下JAVA_HOME,如果是因為后者,可以把JAVA_HOME的目錄改成jdk/bin的目錄,或者可以改一下項目的pom配置文件:文章來源地址http://www.zghlxwxcb.cn/news/detail-750703.html

<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>
            <configuration>
                <!-- 這里需要指定jdk的bin目錄下的javadoc執(zhí)行文件 -->
                <javadocExecutable>${java.home}/../bin/javadoc</javadocExecutable>
            </configuration>
        </execution>
    </executions>
</plugin>

到了這里,關于發(fā)布jar包到maven中央倉庫的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉載,請注明出處: 如若內容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

  • Maven導入sqlserver驅動jar包依賴包到本地倉庫并引用

    Maven導入sqlserver驅動jar包依賴包到本地倉庫并引用

    一、配置maven環(huán)境變量 (1)、找到此電腦右鍵----點擊屬性----選擇高級系統(tǒng)設置----點擊環(huán)境變量----新建系統(tǒng)變量 (2)、新建系統(tǒng)變量:MAVEN_HOME,變量值填你maven解壓的路徑,然后點擊確定。 (3)、在已有的path系統(tǒng)變量里,點擊編輯,在變量值的最后填寫%MAVEN_HOME%bin。 (4)、驗證是

    2023年04月08日
    瀏覽(22)
  • 【擁抱開源】發(fā)布自己的項目到maven中央倉庫

    【擁抱開源】發(fā)布自己的項目到maven中央倉庫

    官網(wǎng)注冊賬號地址 username不能是中文,不讓后面會出問題 一定要選如圖的選項 圖4.1 概要 :填你的項目名 groupid :如果gitee上的項目就填 io.gitee+下圖所示antopen ,如果是公司(有域名和公司郵箱),就填 com.公司名稱 project url :項目地址 SCM url :項目克隆地址(后面以.git結

    2024年02月03日
    瀏覽(17)
  • 一篇搞定發(fā)布自己的類庫到Maven中央倉庫

    一篇搞定發(fā)布自己的類庫到Maven中央倉庫

    在Maven項目中,90%以上的jar包是通過pom文件直接從開源倉庫中獲取依賴jar包文件,然后在項目中進行集成使用。 此時如果你有一個開源項目,那么如何將該開源項目發(fā)布到Maven中央倉庫,讓其他人可以方便的使用,而不是先下載jar,然后install的本地? 本文將通過一步步的操作

    2024年02月05日
    瀏覽(19)
  • 向 Maven 中央倉庫上傳一個修改過的基于jeecg的autoPOI的 jar包記錄

    向 Maven 中央倉庫上傳一個修改過的基于jeecg的autoPOI的 jar包記錄

    1、注冊https://issues.sonatype.org/賬號 下面就代表注冊好了,同時提交的工單也通過了 ?2、這里主要是goupId 需要進行認證,需要到域名注冊商近一個txt的解析,以便確保這個是你的 通過下面來驗證你的域名信息,這里主要是上面的工單號碼要包括進去,我這里是一個鏈接地址作

    2024年02月14日
    瀏覽(23)
  • IDEA上傳jar包到Maven

    ?mvn install:install-file ?\\\"-Dfile=core-3.5.0.jar\\\" ? \\\"-DgroupId=com.thunisoft.zxing\\\" ? \\\"-DartifactId=javase\\\" ?\\\"-Dversion=3.5.0\\\" ? ?\\\"-Dpackaging=jar\\\" ? \\\"-DgeneratePom=false\\\" ?

    2024年02月04日
    瀏覽(13)
  • 【Java 中級】Maven 本地倉庫、中央倉庫、私倉

    【Java 中級】Maven 本地倉庫、中央倉庫、私倉

    ?? 博主介紹 : 博主從事應用安全和大數(shù)據(jù)領域,有8年研發(fā)經(jīng)驗,5年面試官經(jīng)驗,Java技術專家,WEB架構師,阿里云專家博主,華為云云享專家,51CTO 專家博主 ?? 個人社區(qū):個人社區(qū) ?? 個人主頁:個人主頁 ?? 專欄地址: ? Java 初階 ??八股文專題:劍指大廠,手撕

    2024年02月05日
    瀏覽(25)
  • Java Maven項目推送到 Maven 中央倉庫

    當需要在 sonatype 認證 com.xxx 命名空間時,需要將 @.xxx.com 配置域名解析。 記錄類型:TXT 文本內容:驗證的 key。 GPG 下載地址:https://www.gnupg.org/download/index.html Mac 可以使用 brew install gpg 直接安裝 使用方式可參考: https://central.sonatype.org/publish/requirements/gpg/ https://www.jianshu.com/

    2024年04月13日
    瀏覽(20)
  • 個人開源項目如何上傳maven中央倉庫

    個人開源項目如何上傳maven中央倉庫

    最近在寫一些開源項目,想把自己寫的東西放到maven中央倉庫,提供給更多的人使用。所以寫這一篇文章,記錄一下自研開源項目jar包上傳同步maven中央倉庫成功的整個過程,這其中還是有不少的坑的。 一、OSSRH賬號注冊于配置 1.1.賬號注冊 1.2.域名認證 二、安裝GnuPG軟件,并

    2023年04月09日
    瀏覽(33)
  • maven中央倉庫不能訪問的解決辦法

    導入Maven項目,編譯時候出錯,好象是接不上apache.org/maven2,下載不了maven-resources-plugin-2.6.jar 這個jar包 出錯內容: Plain Text code ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 [INFO]?Scanning?for?projects... [INFO] [INFO]?------------------------------------------------------------------------ [INFO]?Building?maven

    2024年02月13日
    瀏覽(21)
  • k8s系列-kuboard創(chuàng)建工作負載 docker上傳java微服務jar包到倉庫的過程

    1.查看環(huán)境中是否存在docker環(huán)境 docker version 2.不存在的話需要創(chuàng)建docker 1.環(huán)境說明 1.開發(fā)人員將java微服務打包成在linux中可運行的jar包,將其傳送給運維人員 2.外網(wǎng)和內網(wǎng)可以傳送文件 3.內網(wǎng)需要有l(wèi)inux服務器,并且配置了docker環(huán)境和命名空間 這里過程是基于k8s的集群kuoard控

    2024年02月05日
    瀏覽(16)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包