前言
本文主要说明如何生成项目构件,并手动上传构件文件到Bintray平台,最后发布到JCenter仓库这一流程。
发布流程。参考上一篇文章,完整发布流程如下:
- 准备工作。定义参数;准备本地待发布项目;配置Bintray平台账号、仓库、Package、版本。
- 生成构件文件。本地生成待发布的构件文件(包括POM文件)。
- 发布到Bintray。上传和发布本地构件文件到Bintray平台。
- 发布到JCenter。发布Bintray平台上的项目到JCenter。
源码地址。本文涉及到的nicelogger
项目Github地址:https://github.com/zhangliangnbu/nice-logger
准备工作
参考上一篇文章,如果已经做了,可以跳过。默认你已经有了一个本地项目,已经创建了Bintray平台账号和Maven仓库。
定义参数
- Bintray平台仓库名称。
android
。 - Bintray平台Package名称。
nicelogger
。 - POM文件
groupId
。com.liang.android
。 - POM文件
artifactId
。nicelogger
。 - POM文件
version
。取0.0.1
。
准备本地项目。略。
配置Bintray平台。根据参数创建Package和版本。
生成构件
生成需要上传到Maven库的四个文件:
nicelogger-0.0.1.aar
nicelogger-0.0.1-sources.jar
nicelogger-0.0.1-javadoc.jar
nicelogger-0.0.1.pom
生成nicelogger-0.0.1.aar
文件
在nicelogger
的build.gradle
最后中添加如下代码,用于重命名生成的aar文件:
1 | // 定义pom文件参数 |
执行./gradlew nicelogger:assembleRelease
生成arr文件,位于library/build/outputs/aar/
中。
生成nicelogger-0.0.1-sources.jar
文件
接着在nicelogger
的build.gradle
最后添加如下代码,建立生成所需文件的任务
1 | // 生成Java源码文件 |
然后执行./gradlew nicelogger:sourcesJar
,就可以生成Java源码文件,位于nicelogger/build/libs/
中。
生成nicelogger-0.0.1-javadoc.jar
文件
接着在nicelogger
的build.gradle
最后添加如下代码,建立生成所需文件的任务
1 | // 生成Javadoc文件 |
然后执行./gradlew nicelogger:javadocJar
,就可以生成Javadoc文件,位于nicelogger/build/libs/
中。
生成nicelogger-0.0.1.pom
文件
有两种方式创建POM文件:
一,参考POM Reference手动创建POM文件,填入相关参数。
二,使用Gradle Maven Plugin生成POM,接着在nicelogger
的build.gradle
最后中添加如下代码
1 | // 生成pom文件 |
后执行./gradlew nicelogger:createPom
,就可以生成所需的POM文件,位于nicelogger/build/libs/
中,内容如下:
1 |
|
生成四个文件后,可以把它们放在一个文件夹里,方面之后的上传操作。
发布到Bintray
上传文件
- 进入上传文件页。在Bintray官网上,进入
{usrname}/android/nicelogger/0.0.1
版本页,点击“Upload Files”进入上传文件页。 - 上传文件。点击“Click to Add Files” 上传四个文件, “Target Repository Path”填
com/liang/android/nicelogger/0.0.1
,一般上传了POM文件后,就会有提示。然后点击“Save Changes”即可。
Target Repository Path为{groupId}/{artifactId}/{version},其中“.”都需要替换为“/”。
发布到Bintray仓库
上传文件完成后,会提示如何处理文件:“Discard”还是“Publish”。选择“Publish”,就会发布文件到Bintray平台的Maven仓库,这样我们就能解析,只不过要带上用户自己的仓库地址而已。
发布到Bintray仓库后,会自动生成
maven-metadata.xml
文件。
用户Bintray仓库地址。发布后的项目在https://dl.bintray.com/{username}/{repository_name}
下可查看,我刚才发布的项目在https://dl.bintray.com/zhangliang/android/com/liang/android/nicelogger/
。
Bintray仓库依赖解析
Gradle项目使用nicelogger
依赖方式如下:
一,添加仓库地址。
在需要此依赖的项目build.gradle
配置仓库地址:
1 | repositories { |
或工程目录build.gradle
下添加配置:
1 | allprojects { |
二,添加依赖。在项目build.gradle
配置依赖
1 | dependencies { |
发布到JCenter
进入nicelogger
的package页面,点击“Add to JCenter”,进入下一页,点击“Send”即可。
发布到JCenter仓库需要审核,主要审核文件格式是否符合规范和以及名称是否唯一等,没有问题的话,一般一个工作日以内都会通过。通过后,可以直接用jcenter作为仓库地址,无需配置用户自己的Bintray仓库地址。
JCenter仓库地址。http://jcenter.bintray.com/{地址化的groupId}
,地址化的groupId
即用“/”代替“.”。
具体详情请见用户指南发布到JCenter。
可能遇到的问题
一,点击“Add to JCenter”报错:
Please fix the following before submitting a JCenter inclusion request: the POM is invalid or was uploaded to the wrong coordinates
我之前是因为文件名不一致才出现这个错误提示。必须为{artifactId}-{version}xxx
等。
终于写完了一个完整的流程,O(∩_∩)O。