手擼一個Spring?Boot?Starter并上傳到Maven中央倉庫
先手擼一個Spring Boot Starter
準(zhǔn)備搞個項目,包含以下幾個功能后邊還會加新功能。
- 配置項加密(已實現(xiàn))
- 服務(wù)調(diào)用鏈
- 數(shù)據(jù)脫敏
- …
我的項目地址:https://github.com/lakernote/laker(求star,看能不能混個免費的Idea license)
代碼很簡單就幾行,有興趣的自己看下哈。
GitHub太卡了,這個就是個嘗試,我后邊會切到Gitee。
例如原始配置項內(nèi)容為:
laker: password: laker11111111111111111
密碼是明文的不安全,我們用AES對稱加密,假設(shè)我們的秘鑰為:1234567890123456
, 把上面的內(nèi)容換為加密后字符串,以enc:
開頭。
laker: password: enc:25d778c22331899a1f79eab82a1d930b9abc4633fb948387c764e5f1f9e5bd3f
項目引入依賴
<dependency> <groupId>io.github.lakernote</groupId> <artifactId>laker-spring-boot-starter</artifactId> <version>1.0.2</version> </dependency>
項目啟動時在命令行加入秘鑰
-Denc.key=A string of 16 characters
例如 -Denc.key=1234567890123456
項目運行后實際得到的就是 laker.password:laker11111111111111111
現(xiàn)在我們來打包上傳到中央倉庫,供其他小伙伴使用吧。
打包上傳到中央倉庫
??????步驟很簡單,人人都能搞,不要慌。申請時間為2022年5月份。
我的項目地址:https://github.com/lakernote/laker(求star,看能不能混個免費的Idea license)
<dependency> <groupId>io.github.lakernote</groupId> <artifactId>laker-spring-boot-starter</artifactId> <version>1.0.2</version> </dependency>
GitHub太卡了,這個就是個嘗試,我后邊會切到Gitee。
已經(jīng)上傳到中央倉庫,大家可以體驗使用。可以在https://search.maven.org/search查詢。
第一步 在issues.sonatype.org注冊一個賬號
地址如下:https://issues.sonatype.org
要記錄下自己的用戶名和密碼,后邊要用的。
密碼要求如下:
- 密碼必須至少有 12 個字符。
- 密碼必須至少包含 1 個大寫字符。
- 密碼必須至少包含 1 個特殊字符,例如 &、%、™ 或 É。
- 密碼必須包含至少 3 種不同的字符,例如大寫字母、小寫字母、數(shù)字和標(biāo)點符號。
- 密碼不得與用戶名或電子郵件地址相似。
第二步 在issues.sonatype.org提交Issue
注意與國外時差問題,晚上干,基本秒回。當(dāng)Issue的Status變?yōu)镽ESOLVED后,就可以進行下一步操作了。
- 項目:看圖片紅色部分
- 問題類型:看圖片紅色部分
- 概要: 說下你項目干啥的
- GroupId: com.github.* 現(xiàn)在不能用了,改為 io.github.lakernote
- ProjectURL: 看圖片紅色部分,填寫項目地址
- SCMURL: 看圖片紅色部分,填寫git地址
- 其他使用默認即可。
注意:你填寫的GroupId要等于你pom中的io.github.lakernote。
填寫完畢后,點擊提交,然后會有人審核讓你在GitHub上建立個項目以用于證明是你的項目。
第三步 配置Maven Setting.xml
https://central.sonatype.org/publish/publish-maven/#distribution-management-and-authentication
<settings> <servers> <server> <id>ossrh</id> <username>your-jira-id</username> <password>your-jira-pwd</password> </server> </servers> </settings>
注意:server
的id
元素值要與第四步即下面的snapshotRepository
的id
元素值和repository
的id
元素值相同。
你不要改就行,使用默認的,把username和password改為第一步你自己的jira用戶名和密碼。
第四步 配置項目的pom.xml
https://central.sonatype.org/publish/requirements/#license-information
整個pom你不想看也可以,直接復(fù)制走傻瓜式用就完事了。
<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>
Javadoc、源附件、GPG 簽名組件
<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> <configuration> <additionalJOptions> <additionalJOption>-Xdoclint:none</additionalJOption> </additionalJOptions> </configuration> <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.5</version> <executions> <execution> <id>sign-artifacts</id> <phase>verify</phase> <goals> <goal>sign</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
項目名稱、描述和 URl
<name>Example Application</name> <description>A application used as an example on how to set up pushing its components to the Central Repository.</description> <url>http://www.example.com/example-application</url>
開源協(xié)議
<licenses> <license> <name>The Apache License, Version 2.0</name> <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url> </license> </licenses>
開發(fā)者信息
<developers> <developer> <name>laker</name> <email>935009066@qq.com</email> <organizationUrl>https://laker.blog.csdn.net</organizationUrl> </developer> </developers>
項目信息
<scm> <connection>scm:git:git://github.com/simpligility/ossrh-demo.git</connection> <developerConnection>scm:git:ssh://github.com:simpligility/ossrh-demo.git</developerConnection> <url>http://github.com/simpligility/ossrh-demo/tree/master</url> </scm>
整體示例 https://github.com/lakernote/laker/blob/main/pom.xml
<?xml version="1.0" encoding="UTF-8"?> <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>io.github.lakernote</groupId> <artifactId>laker</artifactId> <packaging>pom</packaging> <version>1.0.2</version> ... <modules> <module>laker-encrypt</module> <module>laker-spring-boot-starter</module> <module>laker-spring-boot-starter-test</module> </modules> <!-- start --> <name>laker</name> <description>A collection of tools based on Spring Boot</description> <url>https://github.com/lakernote/laker</url> <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>laker</name> <email>935009066@qq.com</email> <organizationUrl>https://laker.blog.csdn.net</organizationUrl> </developer> </developers> <scm> <connection>scm:git:git://github.com/lakernote/laker.git</connection> <developerConnection>scm:git:ssh://github.com:lakernote/laker.git</developerConnection> <url>http://github.com/lakernote/laker/tree/master</url> </scm> <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> <configuration> <additionalJOptions> <additionalJOption>-Xdoclint:none</additionalJOption> </additionalJOptions> </configuration> <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.5</version> <executions> <execution> <id>sign-artifacts</id> <phase>verify</phase> <goals> <goal>sign</goal> </goals> </execution> </executions> </plugin> </plugins> </build> <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> <!-- end --> </project>
第五步 安裝和配置GPG
發(fā)布到Maven倉庫中的所有文件都要使用GPG簽名,以保障完整性。因此,我們需要在本地安裝并配置GPG。
Windows下載地址:https://www.gpg4win.org/
1.文件 - 新建密鑰對
2.在證書列表,右鍵點擊在服務(wù)器上發(fā)布
第六步 項目打包上傳
首先:執(zhí)行命令 mvn clean deploy
或者在idea點擊deploy按鈕
然后:登陸https://s01.oss.sonatype.org/ 去處理你剛剛deploy的jar包
- 選擇
taging Repositories
- 選擇你的項目
- 點擊close
- 點擊release
第七步 處理驗證
上面執(zhí)行完成后,我們?nèi)?code>https://repo1.maven.org/maven2/ 中可以搜索,大概10-30分鐘后可以搜索到。這個時候我們就可以在項目中引用了。
但是同步到中央倉庫搜索可能要4個小時左右。
中央倉庫地址: https://search.maven.org/。
例如我的:https://repo1.maven.org/maven2/io/github/lakernote/laker-spring-boot-starter/
問題 我1.0.1版本發(fā)布錯了,有辦法修改或者刪除嗎?
官方答復(fù)如下:Sonatype 政策禁止在工件發(fā)布后對其進行移除或任何其他修改。即無法覆蓋現(xiàn)有版本。必須發(fā)布一個新的更正版本。
到此這篇關(guān)于手擼一個Spring Boot Starter并上傳到Maven中央倉庫的文章就介紹到這了,更多相關(guān)SpringBoot Starter上傳Maven倉庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IDEA最新激活碼2021(IDEA2020.3.2最新永久激活方法)
這篇文章主要介紹了IDEA最新激活碼2021(IDEA2020.3.2最新永久激活方法),本文通過實例圖文相結(jié)合給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12Value注解支持對象類型ConfigurationProperties功能
這篇文章主要為大家介紹了Value注解支持對象類型ConfigurationProperties功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10java使用內(nèi)存數(shù)據(jù)庫ssdb的步驟
這篇文章主要介紹了java使用內(nèi)存數(shù)據(jù)庫ssdb的步驟,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-12-12