博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android(支持kotlin) 新版Bintray-极简上传Library到JCenter,可上传自定义maven仓库
阅读量:7023 次
发布时间:2019-06-28

本文共 3566 字,大约阅读时间需要 11 分钟。

背景

最近得闲 将封装的开源项目上传到JCenter上,方便供大家使用,但是突然发现Bintray网站更新变化很大, 以前老方法上传,过于复杂,代码量也很多,每次编写新库上传,复制代码心累,大家都懂。于是百度,有没有更简便上传方式 我在网上网上很多博客讲解的 Bintray-极简上传Library到JCenter 发现对自定义maven仓库名配置, 很多博客文章里没有说明,这一篇文章是讲解如何上传自定义maven仓库下。

开始我们的上传之路!


注册

注册是踩坑的第一步,很多博客或者网站都是直接推荐去官网注册:

绝对不要去这里注册

注意:千万别点这里注册,这里现在默认注册的是组织,并不是个人

我就是这一步走错了被这一步坑了,导致一天都没将开源项目提上去

重要的事情说三遍:

个人正确的注册地址:

个人正确的注册地址:

个人正确的注册地址:

后边注册的步骤就很简单了,有github或者google账户的同学直接登录就行了,如果要注册需要注意邮箱不能是国内的邮箱


获取keyuser


创建maven仓库

注意:创建的maven仓库类型都写成maven,仓库名称 任意名字,后面配置信息会用到仓库名称


极简上传

查看了网上的很多上传方法都很复杂,也都亲自实践过,给大家介绍最简单的一种,其他复杂的直接忽略了,因为也不是什么很高深的东西,只要能到达目的就行了!

有兴趣的同学可以去看看源码

前提是你已经将需要开源的项目独立成module,并且已经是com.android.library

1.根目录下的build.gradle中加入上传开源库的依赖:

classpath 'com.novoda:bintray-release:0.8.0'复制代码

2.librarymodule中加入 apply

apply plugin: 'com.novoda.bintray-release'复制代码
  • 注意:bintray-releas的版本 依赖,对应你项目使用 Gradle 版本

    1.bintray-releas version 0.8.0+ 对应 Gradle 是 version 4.1+ (包括4.1)(4.5 不适用)

    2.bintray-releas version 0.7.0 对应 Gradle 是 version 4.1+ (包括4.1)

    3.bintray-releas version 0.6.1 对应 Gradle 是 version 4.1+ (包括4.1)

    4.bintray-releas version 0.5.0 对应 Gradle 是 version 3.4+ (包括3.4)

    5.bintray-releas version 0.4.0 对应 Gradle 是 version 3.3+ (包括3.3)

    6.bintray-releas version 0.3.4 对应 Gradle 是 version 1.3.0+(包括1.3)

如果版本不对应 就有可能项目库上传失败 红线内没有版本号信息

3.如果你开源库中有中文注释在modulebuild.gradle加入格式

allprojects {    repositories {        jcenter()    }    //加上这些    tasks.withType(Javadoc) {        options{ encoding "UTF-8"            charSet 'UTF-8'            links "http://docs.oracle.com/javase/7/docs/api"        }    }}//kotlin类库上传//非常重要 要不它不认识你的项目.kt文件名 其中airpurgeview是你的library名tasks.getByPath(":airpurgeview:releaseAndroidJavadocs").enabled = false复制代码

如何你的类库采用kotlin语言, 请加上tasks.getByPath(":airpurgeview:releaseAndroidJavadocs").enabled = false

4.忽略错误信息:modulebuild.gradle

android {************ lintOptions {        abortOnError false    }}复制代码

5.配置基本信息

publish {    repoName="ycjiang"//仓库名    userOrg = 'ycjiang'      //bintray注册的用户名    groupId = 'com.ycjiang'         //compile引用时的第1部分groupId    artifactId = 'QiniuModule'     //compile引用时的第2部分项目名    publishVersion = '1.0.1'    //compile引用时的第3部分版本号    desc = 'This is a rxbus same of eventbus extend library '//d项目描述    repoName="ycjiang" //你的仓库名称,没有填写默认仓库是maven//这也是很多人上传仓库不对名问题最多情况,    website = '' //github 托管地址}复制代码

6.仓库名重要性

  • repoName 如果没有填写,上传的库默认仓库是maven,这个:bintray-release上传也是最多原因.

  • 很多用户的压根没有这个仓库, 然后百度,发现,Bintray需要手动创建仓库是maven。

  • 既然手动创建仓库,为什么仓库名为何自己用定义仓库名, Bintray是可以新建仓库. repoName 这个属性就可以自己项目上传到自己定义仓库下。

通过配置我们最后的依赖地址=第一部分+第二部分+第三部分;

compile  'com.ycjiang:QiniuModule:1.0.1'复制代码

版本更新只需要修改publishVersion 即可;

7.切换到AndroidStudio temrinal或者cmd后台中运行:

  • 配置基本信息没有填写 bintrayUser和bintrayKey 使用下面
windows 系统:
gradlew clean build bintrayUpload -PbintrayUser=BINTRAY_USERNAME -PbintrayKey=BINTRAY_KEY -PdryRun=false复制代码
os x系统中

如果出现拒绝该命令./gradlew: Permission denied,可以先运行 chmod +x gradlew再运行该命令;第一次运行需要下载文件需要稍微等待。

./gradlew clean build bintrayUpload -PbintrayUser=BINTRAY_USERNAME -PbintrayKey=BINTRAY_KEY -PdryRun=false复制代码

其中BINTRAY_USERNAME换成bintray注册的用户名,BINTRAY_KEY换成自己的APIKEY

8.观察后台输出:

回车执行命令,看到BUILD SUCCESS即上传成功

9.发布项目到公用Jecenter

回到主页的你上传仓库中,点击进入,如果你上次成功即可看见你刚刚上次的开源项目

点击进入项目中,然后点击add加入commit就行了,一般需要等待审核通过,一般5-6小时 commit内容推荐是同英文,不要中文

10.依赖使用

在审核通过前可以通过配置自己私有仓地址使用

在更目录下build.gradle配置地址

allprojects {    repositories {        jcenter()          jcenter(){ url 'http://jcenter.bintray.com/'} //JCenter下载慢测试         maven { url "https://dl.bintray.com/ycjiang/maven" }//审核前可使用    }复制代码

项目中加入依赖:

compile  'com.ycjiang:QiniuModule:1.0.1'复制代码

好了,现在你就可以在你项目中依赖你的开源库了,就是这么简单!


项目

在第一次上传的过程中可以参考我的工程仿照配置


转载地址:http://tnvxl.baihongyu.com/

你可能感兴趣的文章
Instagram 架构分析笔记(转)
查看>>
java http线程池
查看>>
java较全的面试题
查看>>
day3
查看>>
软件程序编码
查看>>
感觉好累
查看>>
使用ant制作hadoop1.1.2的eclipse插件(转载)
查看>>
Css的transform和transition
查看>>
POJ1386Play on Words(欧拉回路)
查看>>
configparser 文件的生成和读写
查看>>
20个PHP程序性能优化的方法
查看>>
关于游戏平衡性工作内容——王者荣耀英雄伤害附录
查看>>
47种常见的浏览器兼容性问题大汇总
查看>>
数据结构与算法预热--线性表是什么?
查看>>
Winform自定义控件实例
查看>>
Siebel NextRecord And DeleteRecord In Loops Skips Record
查看>>
batch normalization在测试时的问题
查看>>
Python时间和日期
查看>>
【BZOJ4298】[ONTAK2015]Bajtocja
查看>>
为什么C语言中int的表示范围是-32768~32767
查看>>