概述

在开发中,我们在引用第三方开源控件的时候,经常会给出如下的gradle dependencies

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

不用再下载,导入等复杂的操作。到底是如何做到的呢?其实是android studio去build.gradle里面定义的Maven仓库中去下载了这些library。
那我们如果想将自己的作品上传到jcenter 共别人来这样很方便的引用,该怎么做呢?

Gradle仓库

Gradle支持以下仓库格式:Ivy仓库;Maven仓库;Flat directory仓库。
如果使用过早期的Android Studio,我们会发现其默认仓库是Maven Central,后来改为了JCenter,可参见这篇文章Android Studio – Migration from Maven Central to JCenter,其实Maven Central (由sonatype.org维护的Maven仓库)和Center(由 bintray.com维护的Maven仓库)是两个标准的Apache Maven文件服务器,都是Maven仓库。Apache Maven是Apache开发的一个工具,提供了用于贡献library的文件服务器。

JCenter:

allprojects { repositories { jcenter() }}

Maven Central:

allprojects { repositories { mavenCentral() }}

同时,我们还看到有类似如下代码:

repositories { maven { url 'https://maven.fabric.io/public' }}

这是作者将library放到了自己定义的Maven仓库服务器上,需要定义服务器地址。

Jcenter仓库

在将library上传到JCenter之前,我们看一下Maven仓库中library是如何在项目中引用的。

  compile 'com.squareup.retrofit2:retrofit:2.0.0-beta3'

这里看到的是compile 后被三个: 分割;即

compile 'GROUP_ID:ARTIFACT_ID:VERSION'

其中,GROUP_ID属性指定依赖的分组
ARTIFACT_ID属性指定依赖的名称
VERSION属性指定外部依赖的版本

当我们添加上述依赖的时候,gradle就会获得相应路径,如上:gradle会到http://jcenter.bintray.com/com/squareup/retrofit2/retrofit/2.0.0-beta3/,并下载相应的library进行编译。

配置本地工程

  1. 注册binary帐号,获取昵称和ApiKey

  1. 配置好昵称和api key,方便下次Publish,在我们项目的根目录下找到local.properties文件,如果没有,就创建一个。输入如下信息
bintray.user= [your name]bintray.apikey= [your api key]
  1. 在项目的build.gradle(不是library)添加maven依赖,最终信息如下
buildscript {//构建过程依赖的仓库    repositories {        jcenter()    }    //构建过程需要依赖的库    dependencies {        classpath 'com.android.tools.build:gradle:1.5.0'        classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'        classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.2'    }}//这里面配置整个项目依赖的仓库,这样每个module就不用配置仓库了allprojects {    repositories {        jcenter()    }}
  1. 在我们的library的model里面创建local.properties 文件,配置library相关信息。
#developerdeveloper.id=BoBoMEedeveloper.name=bobomeedeveloper.email=wbwjx115@gmail.com#projectproject.name=AutoScrollLoopViewPagerproject.groupId=com.bobomee.androidproject.artifactId=scrollloopviewpagerproject.packaging=aarproject.siteUrl=https://github.com/BoBoMEe/AutoScrollLoopViewPagerproject.gitUrl=https://github.com/BoBoMEe/AutoScrollLoopViewPager.gitproject.issueUrl='https://github.com/BoBoMEe/AutoScrollLoopViewPager/issues'#javadocjavadoc.name=AutoScrollLoopViewPager
  1. library的model 里面创建上传脚本bintrayUpload.gradle,添加如下信息。
apply plugin: 'com.github.dcendents.android-maven'apply plugin: 'com.jfrog.bintray'// load propertiesProperties properties = new Properties()File localPropertiesFile = project.file("local.properties");if(localPropertiesFile.exists()){    properties.load(localPropertiesFile.newDataInputStream())}File projectPropertiesFile = project.rootProject.file('local.properties');if(projectPropertiesFile.exists()){    properties.load(projectPropertiesFile.newDataInputStream())}// read propertiesdef projectName = properties.getProperty("project.name")def projectGroupId = properties.getProperty("project.groupId")def projectArtifactId = properties.getProperty("project.artifactId")def projectVersionName = android.defaultConfig.versionNamedef projectPackaging = properties.getProperty("project.packaging")def projectSiteUrl = properties.getProperty("project.siteUrl")def projectGitUrl = properties.getProperty("project.gitUrl")def projectDesc = properties.getProperty("project.desc")def projectIssueUrl = properties.getProperty("project.issueUrl")def developerId = properties.getProperty("developer.id")def developerName = properties.getProperty("developer.name")def developerEmail = properties.getProperty("developer.email")def bintrayUser = properties.getProperty("bintray.user")def bintrayApikey = properties.getProperty("bintray.apikey")def javadocName = properties.getProperty("javadoc.name")group = projectGroupId// This generates POM.xml with proper parametersinstall {    repositories.mavenInstaller {        pom {            project {                name projectName                groupId projectGroupId                artifactId projectArtifactId                version projectVersionName                packaging projectPackaging                url projectSiteUrl                licenses {                    license {                        name 'The Apache Software License, Version 2.0'                        url 'http://www.apache.org/licenses/LICENSE-2.0.txt'                    }                }                developers {                    developer {                        id developerId                        name developerName                        email developerEmail                    }                }                scm {                    connection projectGitUrl                    developerConnection projectGitUrl                    url projectSiteUrl                }            }        }    }}task writeNewPom << {    pom.writeTo("$buildDir/"+projectVersionName+".pom.xml")}// This generates sources.jartask 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))}// This generates javadoc.jartask javadocJar(type: Jar, dependsOn: javadoc) {    classifier = 'javadoc'    from javadoc.destinationDir}artifacts {    archives javadocJar    archives sourcesJar}// javadoc configurationjavadoc {    options{        encoding "UTF-8"        charSet 'UTF-8'        author true        version projectVersionName        links "http://docs.oracle.com/javase/7/docs/api"        title javadocName    }}// bintray configurationbintray {    user = bintrayUser    key = bintrayApikey    configurations = ['archives']    pkg {        repo = "maven"        name = projectName        desc =projectDesc        websiteUrl = projectSiteUrl        issueTrackerUrl = projectIssueUrl        vcsUrl = projectGitUrl        licenses = ["Apache-2.0"]        labels = ['android']        publish = true        publicDownloadNumbers = true    }}
  1. 最后在我们 的library的build.gradle中引入此脚本即可,类似如下。
dependencies {    compile fileTree(dir: 'libs', include: ['*.jar'])    testCompile 'junit:junit:4.12'    compile 'com.android.support:appcompat-v7:22.2.0'} //引入bintrayUpload.gradle脚本apply from: "bintrayUpload.gradle"

ps:在gitignoe中要添加项目下的local.properties文件,不要上传。

上传Maven

经过如上配置,我们的脚本是否可用呢,我们来上传测试一下。运行命令

./gradlew install          //编译library文件(jar,pom等)./gradlew bintrayUpload    //上传library

进入bintray.com检查我们的项目是否上传成功呢?

可以查看files,如果上传成功,会有相应文件。但是我们的library只是上传成功了,并未添加到jcenter哦!如果想让所有人一键引用的话,还需要添加到jcenter。

如图因为我的已经添加到了jcenter,所以下方有个linked to(1),第一次上传应该会不同。

添加Jcenter

在详情页中找到Maven Central标签,鼠标放上去它会提示你去提交到JCenter进行审核,点击进入后,写点内容就可以了,审核过后即可引用了。


当linked to 部分发生变化的时候,我们可以通过URL(如:http://jcenter.bintray.com/com/bobomee/android/scrollloopviewpager/)查看一下文件是否存在,如果存在,即可在studio中引用了。

更多相关文章

  1. Android(安卓)仿Facebook滑动菜单-支持android 2.2
  2. Android(安卓)App设置成Launch
  3. Android(安卓)NDK 编译过程中遇到错误 exception handling disab
  4. Android(安卓)GridLayout 动态添加子控件 + 平均分配空间
  5. Android(安卓)为点击事件添加震动效果
  6. Android项目使用私有maven仓库配置
  7. Android(安卓)添加底层核心服务
  8. android5.0以后 framework 添加资源 编译 id can not find symbo
  9. Android(安卓)Studio官方文档之添加URL和App索引支持

随机推荐

  1. android解析json数组
  2. android:configChanges名词解析(文档翻译)
  3. android在service中使用AsyncHttpClient
  4. Android(安卓)SDK更新 Connection to htt
  5. Android(安卓)ndk 入门5 - opencv实现
  6. Android(安卓)Timer 更好方法
  7. 在服务器上使用 gradle 打包 android 源
  8. android aosp 源码版本
  9. 2013.09.09——— android 判断存储卡是
  10. 八款android日历 [Calendar] 开源项目框