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.