首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android library快速构建上传jcenter

Android library快速构建上传jcenter

作者头像
先知先觉
发布2019-01-21 11:26:40
8510
发布2019-01-21 11:26:40
举报

前言

在使用了AS之后,大家都喜欢使用依赖

compile 'com.android.support:appcompat-v7:25.2.0'

jCenter与maven central

android studio之前默认使用maven central仓库,最新版中已经将jCenter设置为默认仓库,对于开发者来说,jcenter的操作以及管理页面都更加的友好,所以这里选择先将aar上传到jCenter中,之后同步到maven central。在同步到maven central之前,我们需要创建在maven central创建issue,允许指定的groupId同步仓库即可,之后在jCenter中同步完成后,在控制台完成同步即可。
jCenter
 jcenter是一个托管在bintray.com的资源库。你可以在这里找到需要的资源。 为了能在你的项目中使用jcenter,你需要像下面一样,在自己的build.gradle文件中定义自己的资源库。
    { 
        repositories 
    { 
            jcenter() 
    } 
}
maven central

Maven Central是一个托管在sonatype.org的资源库。你可以在这里找到需要的资源。 为了能在你的项目中使用Maven Central,你需要像下面一样,在自己的build.gradle文件中定义自己的资源库。

     allprojects 
         { 
             repositories
              {
               mavenCentral() 
               } 
        }

接下来让我们步入正题。

注册Binary

官网: https://bintray.com

这里写图片描述
这里写图片描述

看到上图两个红框,这里我们要选择下面的那个,因为这两个注册进去的权限不一样,我们需要open source。

让我们看一下区别:

FREE TRIAL

这里写图片描述
这里写图片描述

OPEN SOURCE

这里写图片描述
这里写图片描述

登陆

获取KEY 这里我们需要获取API KEY 后面配置gradle的时候要用。

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

创建package

第一步:

这里写图片描述
这里写图片描述

第二步: 这里有个坑,就是一定要选择maven仓库

这里写图片描述
这里写图片描述

创建好maven仓库之后我们创建一个package。

注册好之后进入,效果如图所示:我们看到Version什么都没有,等会我们就要上传了,之后就会看到完整信息。

这里写图片描述
这里写图片描述

高能预警:::这里还有个坑就是进入后一定要记下工程的路径:

这里写图片描述
这里写图片描述

配置gradle

第一步: 在工程目录下gradle配置如下代码 (project下gradle):

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.2.3'
        //添加如下两个
        classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.2'
        classpath 'com.github.dcendents:android-maven-gradle-plugin:1.5'
    }
}

第二步: 配置library的gradle文件 代码如下 自己对比一下gradle文件,自行添加。

apply plugin: 'com.github.dcendents.android-maven'
apply plugin: 'com.jfrog.bintray'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"

    defaultConfig {
        minSdkVersion 18
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"

    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }

    lintOptions {
        abortOnError false
    }
}

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:25.2.0'
    testCompile 'junit:junit:4.12'
}

def siteUrl = 'https://github.com/libin7278/Factory'   // 项目的主页
def gitUrl = 'https://github.com/libin7278/Factory.git'   // Git仓库的url
group = "com.libin.rxrequest"            // Maven Group ID for the artifact,一般填你唯一的包名 发布到组织名称名字,必须填写
//发布到JCenter上的项目名字,必须填写
def libName = "AndroidFastDevFrame"
// 版本号,下次更新是只需要更改版本号即可
version = "1.0.0"
install {
    repositories.mavenInstaller {
        // This generates POM.xml with proper parameters
        pom {
            project {
                packaging 'aar'
                // Add your description here
                name '结合 Rxjava2 + retrofit2 封装的完美联网框架'     //项目的描述 你可以多写一点
                url siteUrl
                // Set your license
                licenses {
                    license {
                        name 'Rxjava2 + retrofit2'
                        url 'https://github.com/libin7278/Factory'
                    }
                }
                developers {
                    developer {
                        id 'libin'        //填写的一些基本信息
                        name 'Jason'
                        email 'Jasonlibin2@gmail.com'
                    }
                }
                scm {
                    connection gitUrl
                    developerConnection gitUrl
                    url siteUrl
                }
            }
        }
    }
}
task sourcesJar(type: Jar) {
    from android.sourceSets.main.java.srcDirs
    classifier = 'sources'
}
task javadoc(type: Javadoc) {
    source = android.sourceSets.main.java.srcDirs
    classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
}
task javadocJar(type: Jar, dependsOn: javadoc) {
    classifier = 'javadoc'
    from javadoc.destinationDir
}
artifacts {
    archives javadocJar
    archives sourcesJar
}
Properties properties = new Properties()
properties.load(project.rootProject.file('local.properties').newDataInputStream())
bintray {
    user = "libin7278jc"
    key = "3e1fb10e4e7d850e068ea5fee9acc72。。。。"
    configurations = ['archives']
    pkg {
        userOrg="jasonp"
        repo = "RxRequest"
        name = "RxRequest"    //发布到JCenter上的项目名字
        websiteUrl = siteUrl
        vcsUrl = gitUrl
        licenses = ["Apache-2.0"]
        publish = true
    }
}

下面几个信息是最重要的

bintray {
    user = "libin7278jc"
    key = "3e1fb10e4e7d850e068ea5fee9acc。。。。"
    configurations = ['archives']
    pkg {
        userOrg="jasonp"
        repo = "RxRequest"
        name = "RxRequest"    //发布到JCenter上的项目名字
        websiteUrl = siteUrl
        vcsUrl = gitUrl
        licenses = ["Apache-2.0"]
        publish = true
    }
}

高能预警:::这里坑出现了

user:账号名。 key:前面获取到的API key。

以下三个分别对应我们网站上的package路径

        userOrg="jasonp"
        repo = "RxRequest"
        name = "RxRequest"  
这里写图片描述
这里写图片描述

以上信息千万不能填错,不然苦逼了。

接下来我们就可以上传我们刚才配置好的library: 在命令行之行如下代码:

./gradlew clean build bintrayUpload -PdryRun=false 

到看到build success 说明成功了。

这里写图片描述
这里写图片描述

add Jcenter

这是最后一步,马上就要见到福利啦。

这里写图片描述
这里写图片描述

这会我们已经能看到版本号啦 ,这时候我们点击右下角“Add to Jctener”

完美,这时候我们等待审核就好了。 审核通过之后就能使用我们的依赖了。 是不是风雨之后的彩虹,很爽。

这里写图片描述
这里写图片描述

再有坑可以及时联系我,不过你要是按照步骤认真做 应该没什么问题。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年03月13日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
    • jCenter与maven central
    • 注册Binary
      • 让我们看一下区别:
      • 登陆
        • 获取KEY 这里我们需要获取API KEY 后面配置gradle的时候要用。
          • 创建package
          • 配置gradle
          • add Jcenter
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档