??最近閑著看了一下jcenter的使用觉痛,也想將自己使用頻率比較高的東西抽成類庫荠瘪,然后通過compile來使用孕索,提高開發(fā)效率铐达,本來以為挺簡單的,但是網(wǎng)上介紹的比較模糊檬果,很多博客也比較老了瓮孙,不適用,花了我一天的時(shí)間选脊,還是走了很多彎路杭抠,這里記錄下來,希望能幫助到小伙伴們恳啥,現(xiàn)在覺得還是挺簡單的偏灿。
第一步:首先是注冊,這就是我踩的最大的一個(gè)坑钝的,導(dǎo)致我一天都沒有上傳成功翁垂。網(wǎng)上說的都是去jcenter的網(wǎng)站上注冊就可以,其實(shí)不然硝桩,英文好的最好去看英文文檔沿猜,一步一步來操作。
個(gè)人正確的注冊地址:https://bintray.com/signup/oss
個(gè)人正確的注冊地址:https://bintray.com/signup/oss
個(gè)人正確的注冊地址:https://bintray.com/signup/oss
重要的事情說三遍碗脊,一定要到這個(gè)網(wǎng)址去注冊啼肩。
??打開界面是這樣的,一定要選擇我打標(biāo)記的這個(gè)衙伶,默認(rèn)的話是第一個(gè)祈坠,這就是坑,所以一定要看清楚再注冊矢劲。
注:這里用普通的郵箱(qq赦拘,163這些都不好使)是行不通的,最好使用google郵箱或者outlook郵箱芬沉。
注冊完成后界面是這樣的躺同,看下圖:
但是,如果你注冊后界面是下面這樣的:
看不到New Repository花嘶,就說明你注冊錯了笋籽,踩了我的第一個(gè)坑九杂。刪除賬號信息后蘸吓,重新注冊吧。
注冊完成后我們點(diǎn)擊Add New Repository涂邀,新建一個(gè)倉庫。
注:創(chuàng)建的maven倉名字和類型都要寫成maven侍芝,如下圖所示:
然后我們開始獲取user和key研铆,至于為什么要,我們后面再說:
這樣我們jcenter的工作就做好了州叠,然后準(zhǔn)備我們上傳的開源項(xiàng)目棵红,這個(gè)比較簡單,我就隨便說了咧栗。
第一步:
??先新建一個(gè)項(xiàng)目逆甜,然后在這個(gè)項(xiàng)目下新建一個(gè)Android LIbrary的Module,自己的開源庫就在這個(gè)Module里面開發(fā)致板,如下圖:
第二步:
??在這個(gè)新建的Module里面交煞,開發(fā)自己的開源項(xiàng)目,然后斟或,在原來的項(xiàng)目里是可以直接引用Module里在代碼的素征。但運(yùn)行的時(shí)候會報(bào)錯,需要在項(xiàng)目的build.gradle中添加如下代碼:
compile project(':CommonUtilLibrary')
后面單引號里面萝挤,是自己創(chuàng)建的Module名字御毅。
然后,再重新運(yùn)行整個(gè)項(xiàng)目怜珍,就可以把Module也編譯進(jìn)去了端蛆。
第三步:
??編寫工程的build.gradle文件,記住绘面,是工程的欺税。
先打開項(xiàng)目的build.gradle文件侈沪,一定是項(xiàng)目的build文件揭璃,然后在里面添加如下代碼:
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.1'
classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.2'
classpath 'com.github.dcendents:android-maven-gradle-plugin:1.5'
}
}
記住,代碼有的就保留下來亭罪,沒有的加上去瘦馍。
注意:這里Sync有時(shí)候會報(bào) Error:(2, 0) No service of type Factory...這樣的錯誤,主要是因?yàn)檫@一行:
classpath 'com.github.dcendents:android-maven-gradle-plugin:1.5'
如果報(bào)錯了的話应役,就自己去官網(wǎng)上看最新的插件版本號情组,改了就可以了。
這里添加完后完整的build.gradle應(yīng)該是這樣的:
然后再打開將要上傳的Module的build.gradle文件箩祥,添加如下代碼:
apply plugin: 'com.github.dcendents.android-maven'
apply plugin: 'com.jfrog.bintray'
def siteUrl = 'https://github.com/caijin199410/CommonUtil.git' // 項(xiàng)目的主頁 這個(gè)是說明院崇,可隨便填
def gitUrl = 'https://github.com/caijin199410/CommonUtil.git' // Git倉庫的url 這個(gè)是說明,可隨便填
group = "com.abrahamcaijin" // 這里是groupId ,必須填寫 一般填你唯一的包名袍祖,對應(yīng)com.squareup.okhttp3:okhttp:3.4.1中的com.squareup.okhttp3部分
install {
repositories.mavenInstaller {
// This generates POM.xml with proper parameters
pom {
project {
packaging 'aar'
// Add your description here
name 'CommonUtil' //項(xiàng)目描述
url siteUrl
// Set your license
licenses {
license {
name 'The CommonUtil Software License, Version 1.0.0'
url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
}
}
developers {
developer {
id 'caijinabraham' //填寫開發(fā)者的一些基本信息
name 'caijinabraham' //填寫開發(fā)者的一些基本信息
email 'caijinabraham@outlook.com' //填寫開發(fā)者的一些基本信息
}
}
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"
charSet 'UTF-8'
author true
version true
links "http://docs.oracle.com/javase/7/docs/api"
}
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.file('local.properties').newDataInputStream())
bintray {
// userOrg=properties.getProperty("bintray.user")
user = properties.getProperty("bintray.user") //讀取 local.properties 文件里面的 bintray.user
key = properties.getProperty("bintray.apikey") //讀取 local.properties 文件里面的 bintray.apikey
configurations = ['archives']
pkg {
repo = "maven"
name = "CommonUtil" //發(fā)布到JCenter上的項(xiàng)目名字底瓣,必須填寫,對應(yīng)com.squareup.okhttp3:okhttp:3.4.1中的okhttp
publishVersion = ‘1.0.0’//發(fā)布到JCenter上的項(xiàng)目版本號
websiteUrl = siteUrl
vcsUrl = gitUrl
licenses = ["Apache-2.0"]
publish = true
}
}
添加完成后蕉陋,完整的build.gradle應(yīng)該是這樣的:
??最后需要在本地的local.properties里面添加以下內(nèi)容:
bintray.user=YOUR_BINTRAY_USERNAME
bintray.apikey=YOUR_BINTRAY_API_KEY
如圖所示:
第四步:
??打開android studio的命令行:
輸入如下命令:
輸入命令:
gradlew install
gradlew bintrayUpload
當(dāng)這兩個(gè)命令都成功顯示BUILD SUCCESSFUL就可以了捐凭,或者不執(zhí)行上面這兩個(gè)命令拨扶,直接合成執(zhí)行下面這個(gè)命令就可以了:
gradlew clean build bintrayUpload -PbintrayUser=BINTRAY_USERNAME -PbintrayKey=BINTRAY_KEY -PdryRun=false
記住要把user和key換成自己的,同樣要顯示BUILD SUCCESSFUL才可以茁肠。
最后要將項(xiàng)目發(fā)布到j(luò)center:
??上傳開源庫到j(luò)center的辦法很多患民,可以百度,這里看看我的就可以了垦梆,打開jcenter的主頁匹颤,進(jìn)入自己新建的maven倉庫里面,你就可以看到自己推上來的開源項(xiàng)目了托猩,如下圖所示:
然后需要等待審核通過惋嚎,一般5-6小時(shí)。在審核通過前可以通過配置自己私有倉地址使用站刑。
然后在項(xiàng)目的根目錄下build.gradle配置地址:
然后在要是使用的Module的build.gradle里面添加依賴:
項(xiàng)目中加入依賴即可:
compile 'com.abrahamcaijin:ComonUtil:1.0.0'
注意:如果這里提示依賴不成功另伍,可以再后邊加上@arr,審核通過以后可以去掉后面的@arr,暫時(shí)發(fā)現(xiàn)os系統(tǒng)上傳后不需要加入便可成功绞旅,windows系統(tǒng)上傳需要加入@arr
compile 'com.abrahamcaijin:ComonUtil:1.0.0@aar'
??然后現(xiàn)在是1.0.0版本摆尝,我以后想增加、迭代怎么辦因悲?
??這個(gè)非常簡單堕汞,當(dāng)你的Library代碼更改后,只需要更改一下上面的配置里面的publishVersion晃琳,運(yùn)行
gradlew clean build bintrayUpload -PdryRun=false
就可以更新版本號了讯检。這樣,整個(gè)過程就結(jié)束了卫旱。
??好了人灼,現(xiàn)在你就可以在你項(xiàng)目中依賴你的開源庫了,就是這么簡單顾翼!有不懂的聯(lián)系我投放。
轉(zhuǎn)載自:http://blog.csdn.net/u014727709/article/details/71104201
歡迎start,歡迎評論适贸,歡迎指正