Android Studio公布到Jcenter

1.前言

拥抱开源。热爱开源,将我们觉得不错的代码开源到gihtub。将我们的库公布到jcenter\mevan等。

2.准备工作

2.1 准备

2.2 插件引入

在根文件夹的gradle文件下增加

classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.2'
        classpath 'com.github.dcendents:android-maven-plugin:1.2'

个人觉得这1个最好保持一直。
最后我们根文件夹下的gradle文件变成这个样子

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:1.3.0'
        classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.2'
        classpath 'com.github.dcendents:android-maven-plugin:1.2'
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

2.3 在根文件夹下创建一个bintray.gradle文件(必须这名字)

group = PROJ_GROUP
version = PROJ_VERSION
project.archivesBaseName = PROJ_ARTIFACTID

apply plugin: 'com.jfrog.bintray'
apply plugin: 'maven-publish'

task sourcesJar(type: Jar) {
    from android.sourceSets.main.java.srcDirs
    classifier = 'sources'
}

task javadoc(type: Javadoc) {
    source = android.sourceSets.main.java.srcDirs
    classpath += configurations.compile
    classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
}

task javadocJar(type: Jar, dependsOn: javadoc) {
    classifier = 'javadoc'
    from javadoc.destinationDir
}

javadoc {
    options{
        encoding "UTF-8"
        charSet 'UTF-8'
        author true
        version true
        links "http://docs.oracle.com/javase/7/docs/api"
        title PROJ_ARTIFACTID
    }
}

artifacts {
    archives javadocJar
    archives sourcesJar
}

def pomConfig = {
    licenses {
        license {
            name "The Apache Software License, Version 2.0"
            url "http://www.apache.org/licenses/LICENSE-2.0.txt"
            distribution "repo"
        }
    }
    developers {
        developer {
            id DEVELOPER_ID
            name DEVELOPER_NAME
            email DEVELOPER_EMAIL
        }
    }
    //这里有引號,而且有个空格,否则生成不了依赖。主要是这里的dependencies并非build.gradle里的dependencies,而gradle会把他当成自身的dependencies处理
    "dependencies " {
//        dependency{
//            groupId "com.alibaba"
//            artifactId "fastjson"
//            "version " "1.2.6"
//            //同dependencies
//        }
    }

}

publishing {
    publications {
        mavenJava(MavenPublication) {
            artifactId PROJ_ARTIFACTID

            pom{
                packaging 'aar'
            }
            pom.withXml {
                def root = asNode()
                root.appendNode('description', PROJ_DESCRIPTION)
                root.children().last() + pomConfig
            }
        }
    }
}

bintray {
    Properties properties = new Properties()
    properties.load(project.rootProject.file('local.properties').newDataInputStream())

    user = properties.getProperty('BINTRAY_USER');
    key = properties.getProperty('BINTRAY_KEY');



    configurations = ['archives']
    publications = ['mavenJava']
    publish = true

    pkg {
        repo = 'maven'
        name = PROJ_NAME
        desc = PROJ_DESCRIPTION
        websiteUrl = PROJ_WEBSITEURL
        issueTrackerUrl = PROJ_ISSUETRACKERURL
        vcsUrl = PROJ_VCSURL
        licenses = ['Apache-2.0']
        publicDownloadNumbers = true
    }
}

上述文件差点儿不用改动,假如你将要上传的包 包括其它的三方库。

在以下块中进行申明

"dependencies " {
//        dependency{
//            groupId "com.alibaba"
//            artifactId "fastjson"
//            "version " "1.2.6"
//            //同dependencies
//        }
    }

通俗易懂,一目了然,就不多做解释了,而且在根文件夹下的gradle.properties文件里增加


PROJ_GROUP=这里改成groupId,比方com.android.support
PROJ_VERSION=这里改成库版本号。比方22.2.0
PROJ_NAME=这里改成库名字,比方appcompat
PROJ_WEBSITEURL=这里改成github地址。比方https://github.com/android/appcompat
PROJ_ISSUETRACKERURL=这里改成issue地址,比方https://github.com/android/appcompat/issues
PROJ_VCSURL=这里改成版本号控制地主,比方https://github.com/android/appcompat.git
PROJ_DESCRIPTION=这里改成库的描写叙述信息
PROJ_ARTIFACTID=这里改成库的标示。比方appcompat-v7

DEVELOPER_ID=这里改成开发人员id。比方
DEVELOPER_NAME=这里改成开发人员名字。比方android
DEVELOPER_EMAIL=这里改成开发人员邮箱,比方someone@android.com

2.4 剩余配置

  • 在Model相应的gralde文件里配置签名\引入bintray.gradle,终于代码例如以下。如看不懂配置相关,阅读这篇 或者自行阅读gradle for android

apply plugin: 'com.android.application'

android {
    compileSdkVersion 23
    buildToolsVersion "23.0.2"

    defaultConfig {
        minSdkVersion 19
        targetSdkVersion 23
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    //compile 'com.android.support:appcompat-v7:23.1.1'

}
apply from:'../bintray.gradle'

注意bintray.gradle 一定要放在文件最以下。

  • 配置BINTRAY_KEY 和BINTRAY_USER 也就是一開始注冊的那个
    这里写图片描写叙述
    guolei1130 为我的username,查看key 点击edit,
    这里写图片描写叙述
    点api key ,show 就可以看到。
    在根文件夹下的local.properties 配置。
BINTRAY_KEY=e21c3f96df17xxxxxxxx
BINTRAY_USER=guolei1130

这里相应的是bintray.gradle中的这一段代码。当然,你能够改动这段代码,将这2个属性写在任何位置

Properties properties = new Properties()
    properties.load(project.rootProject.file('local.properties').newDataInputStream())

    user = properties.getProperty('BINTRAY_USER');
    key = properties.getProperty('BINTRAY_KEY');

最后。sync now。

3.上传前准备

3.1 生成aar 包(上传)

这里写图片描写叙述
build,生成相应的aar包。

3.2 生成jardocjar sourcesjar

在model 相应的other task中。找到上面2个。点击生成 一般不慧出错

3.3 在publish中点击task生成pom文件

这里写图片描写叙述
点击第二个就可以

3.4 上传

点击上图中的第一个task,假设出错,依据错误排查就可以,一般就是身份验证的相关问题。

4. 导入的jcenter(需经过审核)

这里写图片描写叙述
这个mevan仓库就是我刚才上传的,可是我们须要将他导入到jcenter 中。点击jcenter.点击有側导入。筛选将要导入的库。等待管理员审核就可以。
这里写图片描写叙述

5. 最后来看下我的库

github地址,求个star
最后来张图证明我是刚刚上传的。
这里写图片描写叙述

没错,就是这么so easy.

posted @ 2018-04-03 09:08  llguanli  阅读(230)  评论(0编辑  收藏  举报