利用Gradle釋出專案到JCenter、Maven
利用Gradle釋出專案到JCenter
Android Studio將遠端倉庫預設指定為Jcenter倉庫,位於Bintray網站。Bintray網站下面還有其他好幾個倉庫。本文主要介紹如何將Android專案釋出到Jcenter。
註冊Bintray賬號
Bintray官網:https://bintray.com
獲取APIKey
上傳專案之前我們需要兩樣東西,一個就是使用者名稱,另一個是APIKey。APIKey可在這裡檢視。
外掛依賴
在專案最外層的build.gradle新增“gradle-bintray-plugin”以及“android-maven-plugin”外掛的依賴。
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.1.0'
classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'
classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.0'
}
}
allprojects {
repositories {
jcenter()
}
}
Module配置
在需要釋出到Jcenter的module(比如library)的build.gradle裡配置以下內容:
apply plugin: 'com.android.library'
apply plugin: 'com.github.dcendents.android-maven'
apply plugin: 'com.jfrog.bintray'
version = "1.0.0" // 版本號
android {
compileSdkVersion 23
buildToolsVersion "23.0.3"
resourcePrefix "bankcardformat" // 隨意命名
defaultConfig {
minSdkVersion 15
targetSdkVersion 23
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
compile 'com.android.support:appcompat-v7:23.+'
compile fileTree(dir: 'libs', include: ['*.jar'])
}
def siteUrl = 'https://github.com/smuyyh/BankCardFormat' // Git專案主頁
def gitUrl = 'https://github.com/smuyyh/BankCardFormat.git' // Git倉庫url
group = "com.yuyh.bankcardformat" // 一般為包名
install {
repositories.mavenInstaller {
// 生成POM.xml
pom {
project {
packaging 'aar'
name 'Android BankCardFormat' // 專案描述
url siteUrl
licenses {
license {
name 'The Apache Software License, Version 2.0'
url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
}
}
developers {
developer { // 開發者個人資訊
id 'smuyyh'
name 'smuyyh'
email 'smuyyh@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) {
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" // 釋出到Maven庫
name = "BankCardFormat" // 釋出到JCenter上的專案名字
websiteUrl = siteUrl
vcsUrl = gitUrl
licenses = ["Apache-2.0"]
publish = true
}
}
配置Username和APIKey
在local.properties檔案配置Username和APIKey。
bintray.user = xxxx
bintray.apikey = xxxx
正常情況下local.properties應該加入到.gitignore檔案裡,因為這兩項屬於隱私資訊,無需上傳到GitHub。當然了,也可把bintray.user及bintray.apiKey配置在Gradle使用者目錄下的gradle.properties(不存在則新建),例如Windows是在C:/user/username/.gradle,OSX和Linux在~/.gradle
ReBuild
Rebuild一下專案,會發現在/build/outputs/aar下生成兩個檔案,這就是library打包出來的二進位制檔案。
上傳專案到Jcenter
在Android Studio的Terminal執行以下命令:
gradlew javadocJar
gradlew sourcesJar
gradlew install
gradlew bintrayUpload
執行成功之後,在Bintray個人主頁下面可以看到Maven多了一個Package。
申請專案加入Jcenter
申請地址:https://bintray.com/bintray/jcenter
搜尋剛剛上傳的專案,並選中。或者進入專案主頁,點選右下角“Add to Jcenter”
等待稽核
稽核速度挺快,一般幾個小時左右會通過。Bintray會向您傳送一條成功的資訊。那麼就完成上傳了。
專案依賴
dependencies {
compile 'com.yuyh.bankcardformat:library:1.0.0'
}
專案更新
上傳的庫進行升級的時候,須更改build.gradle下的version、versionCode、versionName,否則無法進行打包上傳。更改完之後重新執行上傳專案到Jcenter步驟。上傳完成可在專案主頁下看到更新的版本號。
問題
若在上傳的時候,出現GBK編碼錯誤,嘗試在task javadoc(type: Javadoc) 下設定UTF-8編碼:
options.encoding = “UTF-8”
無法解決請參考以下這個Gradle檔案的配置:
https://github.com/msdx/gradle-publish/blob/master/bintray.gradle
相關文章
- 【Android AAR】快速釋出 Android Library 專案到 JCenterAndroid
- 使用gradle外掛釋出專案到nexus中央倉庫Gradle
- 利用jitpack.io釋出Android、Java專案,通過gradle方式引用AndroidJavaGradle
- maven 專案轉化成 gradle 專案實踐MavenGradle
- 使用Gradle釋出工件到Maven倉庫GradleMaven
- Android:一個專案提交多個module到JCenterAndroid
- Gradle專案Build的時候,頻繁報Unknown host 'jcenter.bintray.com' 錯誤GradleUI
- Apache Maven 3.6.1 釋出,專案管理和構建工具ApacheMaven專案管理
- 建立Maven專案出錯Maven
- flutter釋出專案到pub的流程Flutter
- 在idea中利用spingboot建立maven專案IdeabootMaven
- 如何在maven專案或者gradle專案中搭建swagger-本地測試工具MavenGradleSwagger
- 教你一步步釋出一個開源庫到 JCenter
- Gradle實戰及Maven專案遷移採坑記錄GradleMaven
- 釋出jar包到maven中央倉庫JARMaven
- 建立Maven專案出錯 pom出錯Maven
- 圖文教程:從0到1將專案釋出到 Maven 中央倉庫Maven
- qml釋出專案
- jenkins專案釋出Jenkins
- 使用DHorse釋出SpringBoot專案到K8SSpring BootK8S
- 教你釋出vue+.netCore專案到伺服器VueNetCore伺服器
- 手把手教你釋出自己的開源庫到 Jcenter
- 利用Git subtree 部署專案到 GitHubGithub
- 利用 SonarScanner 靜態掃描 Rainbond 上的 Maven 專案AIMaven
- 【Java】【專案構建】Idea中設定Gradle/Maven多模組依賴JavaIdeaGradleMaven
- Maven 教程之釋出 jar 到私服或中央倉庫MavenJAR
- 釋出構件到 Maven 中央倉庫遇到的坑Maven
- QT從入門到入土(八)——專案打包和釋出QT
- Bintray專案釋出-BintrayRelease
- IDEA Maven無法新增依賴到專案中IdeaMaven
- 【Java】【Gradle】Gradle構建SpringBoot專案,Gradle模組化管理JavaGradleSpring Boot
- Maven 專案文件Maven
- Maven 專案模板Maven
- 使用IDEA建立gradle專案IdeaGradle
- Gradle構建SpringBoot專案GradleSpring Boot
- 專案構建工具 GradleGradle
- Gradle之多專案構建Gradle
- idea gradle 專案依賴IdeaGradle
- 利用IDEA建立gradle構建的Java多模組專案(太清晰了)IdeaGradleJava