博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android Studio公布到Jcenter
阅读量:6617 次
发布时间:2019-06-25

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

1.前言

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

2.准备工作

2.1 准备

  • 注意model为android library项目

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_GROUPversion = PROJ_VERSIONproject.archivesBaseName = PROJ_ARTIFACTIDapply 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.supportPROJ_VERSION=这里改成库版本号。比方22.2.0PROJ_NAME=这里改成库名字,比方appcompatPROJ_WEBSITEURL=这里改成github地址。比方https://github.com/android/appcompatPROJ_ISSUETRACKERURL=这里改成issue地址,比方https://github.com/android/appcompat/issuesPROJ_VCSURL=这里改成版本号控制地主,比方https://github.com/android/appcompat.gitPROJ_DESCRIPTION=这里改成库的描写叙述信息PROJ_ARTIFACTID=这里改成库的标示。比方appcompat-v7DEVELOPER_ID=这里改成开发人员id。比方DEVELOPER_NAME=这里改成开发人员名字。比方androidDEVELOPER_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=e21c3f96df17xxxxxxxxBINTRAY_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. 最后来看下我的库

最后来张图证明我是刚刚上传的。
这里写图片描写叙述

没错,就是这么so easy.

你可能感兴趣的文章
中国信息通信研究院发布《网络安全产业白皮书(2017)》
查看>>
关于对centos bash_profile的初步认识
查看>>
Python学习(1)--变量与表达式
查看>>
Flutter环境搭建
查看>>
zabbix 获取Windows Server 信息
查看>>
菜鸟学Linux 第041篇笔记 常见系统故障排除
查看>>
postfix服务
查看>>
测试电脑的存储方式(大端or小端)
查看>>
puppet自动化运维工具安装配置
查看>>
centos7iptables和rc.local问题
查看>>
Provisioning Services 7.6 入门到精通系列之十一:批量导入目标设备
查看>>
监控软件之二nagios
查看>>
Mysql集群与调优
查看>>
硬盘修复
查看>>
windows批处理命令FOR的巧用
查看>>
SAMBA客户端提示 NT_STATUS_HOST_UNREACHABLE 错误提示的解决办法
查看>>
shell 比较两个文本不同
查看>>
洛可可连振:产品与其追求销量,不如设计服务,关键是用户
查看>>
python 函数学习笔记一
查看>>
流程控制-if条件判断
查看>>