使用Gradle發(fā)布項目到JCenter倉庫

JCenter現(xiàn)在是Android Studio中repositories的默認節(jié)點了,之前是Maven的,不過JCenter是兼容Maven的,所以放心使用。

  1. 申請Bintray賬號
  1. 生成jar/aar包
  • 這一步需要android-maven-plugin插件,所以我們需要在項目的build.gradle(、項目最外層的build.gradle文件)中添加這個構(gòu)建依賴,如下:
buildscript {
   repositories {
       jcenter()
   }
   dependencies {
       classpath 'com.android.tools.build:gradle:2.0.0'
       //自動化maven打包插件
       classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'
   }
}

allprojects {
   repositories {
       jcenter()
   }
}

注意自動化maven打包插件的版本,網(wǎng)速查到的資料寫的都是1.0或1.1;gradle升級后已經(jīng)不能再用舊版本了

  • 然后在你需要發(fā)布的那個module(我這里的即是library)的build.gradle里配置如下內(nèi)容:
 apply plugin: 'com.android.library'
 apply plugin: 'com.github.dcendents.android-maven'
 apply plugin: 'com.jfrog.bintray'

 version = "1.6.4"

 android {
     compileSdkVersion 23
     buildToolsVersion "23.0.3"
     resourcePrefix "numchoose_"

     defaultConfig {
         minSdkVersion 14
         targetSdkVersion 23
         versionCode 31
         versionName version
     }
     buildTypes {
         release {
             minifyEnabled false
             proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
         }
     }
 }

 def siteUrl = 'https://github.com/nesror/NumChooseView' // 項目的主頁
 def gitUrl = 'https://github.com/nesror/NumChooseView.git' // Git倉庫的url
 group = "cn.yzapp.numchooseview" // 一般填你唯一的包名
 install {
     repositories.mavenInstaller {
         pom {
             project {
                 packaging 'aar'
                 //項目描述
                 name 'Android number choose view'
                 url siteUrl
                 // 開源協(xié)議
                 licenses {
                     license {
                         name 'The Apache Software License, Version 2.0'
                         url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
                     }
                 }
                 developers {
                    //填寫的基本信息
                     developer {
                         id 'nestor'
                         name 'nestor'
                         email 'nestor@yzapp.cn'
                     }
                 }
                 scm {
                     connection gitUrl
                     developerConnection gitUrl
                     url siteUrl
                 }
             }
         }
     }
 }

 // 注釋掉不上傳源碼
 task sourcesJar(type: Jar) {
     from android.sourceSets.main.java.srcDirs
     classifier = 'sources'
 }
 task javadoc(type: Javadoc) {
     options.encoding = "utf-8"
     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 = properties.getProperty("bintray.user")
     key = properties.getProperty("bintray.apikey")
     configurations = ['archives']
     pkg {
         repo = "maven"
         name = "NumChooseView"    //發(fā)布到JCenter上的項目名字
         websiteUrl = siteUrl
         vcsUrl = gitUrl
         licenses = ["Apache-2.0"]
         publish = true
     }
 }
  • 配置好上述后需要在你的項目的根目錄上的local.properties文件里(一般這文件需gitignore,防止泄露賬戶信息)配置你的bintray賬號信息。
bintray.user=your_user_name
bintray.apikey=your_apikey
  1. 這一步為止,就可以把你項目生成到本地的倉庫中了,Android Studio中默認即在Android\sdk\extras\android\m2repository這里,所以我們可以通過如下命令執(zhí)行生成:
  • gradlew install
  1. 上傳到Bintray
  • 上傳到Bintray需要gradle-bintray-plugin的支持,所以在最外層的build.gradle里添加構(gòu)建依賴:
   dependencies {
       classpath 'com.android.tools.build:gradle:2.0.0'
       //自動化maven打包插件
       classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'
       //自動上傳至Bintray平臺插件
       classpath "com.jfrog.bintray.gradle:gradle-bintray-plugin:1.4"
   }
  • 然后執(zhí)行如下命令完成上傳:
  • gradlew bintrayUpload
  1. 申請你的Repo添加到JCenter
  1. 使用
  1. 可能會遇到的問題
  • 生成javaDoc報錯:
  • javaDoc注釋中有中文:
  • 注釋中非javadoc中規(guī)定的注解:
    如(以下只有@author是可以用的):
    /**
    * @author: xxx
    * @time: 4/9 009-11:56.
    * @email: xxx@xxx.com
    * @desc:
    */
    
  • 還有其他很多,已經(jīng)忘記了
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容