将自己写好的Android Library项目(即aar包)上传到公共的JCenter仓库,这样让其他人更方面的使用。目前JCenter仓库支持maven,gradle,Ivy三种方式。
1. 本地环境
使用环境以及插件版本的不同可能造成上传失败,所以先说明一下我使用的环境信息:
Android Studio 2.2
Gradle 2.2.0
android-maven-gradle-plugin
插件: 1.5版本 (具体请看下面使用)gradle-bintray-plugin
插件: 1.6 版本
2. 注册账号
首先需要在 http://bintray.com/
注册一个账号(自备梯子),或者使用github
账号登录也可以。
注册完成后,在个人 [edit profile](https://bintray.com/profile/edit)
页面里找到API Key
,后面会用到这个 API Key
。
3. 创建Project以及Module
创建好Project以及Module之后,请先检查 project build.xml
, 检查gradle
版本,因为1.1.0
版本的可能会导致javadoc
失败,所以你需要升级你的 gradle
版本。project build.xml
的内容如下:
|
|
4. 在Project build.xml中添加所需的插件
在project build.xml
中的dependencies
节点下追加如下的代码:
|
|
- android-maven-gradle-plugin 插件是用来打包 Maven所需文件的。git地址,https://github.com/dcendents/android-maven-gradle-plugin
- gradle-bintray-plugin 插件是用来将生成的 Maven所需文件上传到Bintray的。git地址:https://github.com/bintray/gradle-bintray-plugin
5. 配置项目信息
在library module
目录下,新建一个文件project.properties
,在该文件中写上如下的信息,这些信息在后面的bintrayUpload.gradle
中将会用到。
|
|
6. 配置Bintray账号以及开发者信息
在library module
目录下,新建一个文件local.properties
,在该文件中写上如下的信息,这些信息在后面的bintrayUpload.gradle
中将会用到。
[注意]: 要将local.proerties
文件加入忽略列表,以免被提交到Github或其他网站泄露个人信息
7. 配置bintrayUpload.gradle
首先下载 bintrayUpload.gradle 文件,并把它放在library module
目录下。然后修改library module
的build.xml
文件,在文件的最后添加上
[注意]: 一定是在module build.xml
的最后添加
8. 执行命令打包并上传到Bintray
在Android studio
中打开Terminal
,执行gradle bintrayUpload
命令进行上传。
在这之前,可以通过gradle install
检查一下编译是否有错。
9. 请求提交项目到JCenter
如果上传成功,你就会在bintray
网站的个人主页看到上传的library module
进入到项目详情,在右下角的Linked To
区域点击Add to JCenter
,然后点击Send
即可。
然后就等待审核,一般大概需要4到5个小时,审核通过后会给你发邮件通知你,并且以后更新项目就不需要再审核了。
10. gradle导入使用
当审核通过,别人就可以一句话导入你的项目了,例如:
11. 遇到的坑
1. 保持你的library module的名字和artifactId一样
因为在Bintray
上你的项目的maven-metadata.xml
文件的路径是gruopId+"/"+module
名称。
2. Error: Library projects cannot set applicationId. applicationId is set to …
出现在错误的原因在于library的build.gradle
里的defaultConfig
存在applicationId
。
3. Error:No service of type Factory available in ProjectScopeServices.
出现这个错误的原因在于project build.xml
的android-maven-gradle-plugin
版本太低,直接将版本提高就好,具体版本信息请查看android-maven-gradle-plugin
的github,https://github.com/dcendents/android-maven-gradle-plugin。
4. Execution failed for task ‘:proxx:javadoc’.> Javadoc generation failed. Generated Javadoc options file (useful for troubleshooting):
在project
的build.xml
中加入如下代码即可解决:
tasks.getByPath(":probe:javadoc").enabled = false
[参考文献]