Android SDK开发之 aar 打包攻略

一、Android中aar上传到本地Maven或者Nexus

project级别下创建一个 upload_local.gradle文件,名字随便起
//引入maven 插件
apply plugin: 'maven'

//打包main目录下代码和资源的 task
task androidSourcesJar(type: Jar) {
    classifier = 'sources'
    from android.sourceSets.main.java.srcDirs
}
//配置需要上传到maven仓库的文件
artifacts {
    archives androidSourcesJar
}

//这几个定义也可以放在 各自module下的 gradle.properties文件中
def GROUP_ID = "com.jzw"
def ARTIFACT_ID = "components"
def VERSION = "1.0.0"

//上传到Maven仓库的task
uploadArchives {
    repositories {
        mavenDeployer {
            //指定maven仓库url
            repository(url: "http://localhost:8081/nexus/content/repositories/releases/") {
                //nexus登录默认用户名和密码
                authentication(userName: "admin", password: "admin123")

                pom.groupId = GROUP_ID// 唯一标识(通常为模块包名,也可以任意)
                pom.artifactId = ARTIFACT_ID // 项目名称(通常为类库模块名称,也可以任意)
                pom.version = VERSION // 版本号
            }
            //解决生成的pom 没有groupid 和版本号的问题
            pom.whenConfigured { pom ->
                pom.dependencies.forEach { dep ->
                    if (dep.getVersion() == "unspecified") {
                        println("--modify the dependenies module in pom.xml--->>" + dep.getArtifactId())
                        dep.setGroupId(GROUP_ID)
                        dep.setVersion(VERSION)
                    }
                }
            }
        }
    }
}
在需要打包aar的module 中引入gradle

一般在build.gradle的底部引入
apply from: "upload_local.gradle"

执行打包上传的任务

在studio的Gradle中对应的module下找到 upload--> uploadArchives 任务执行即可

使用打包好的aar

project 下的build.gradle中配置本地maven的仓库的地址, 之后使用implamentation 引入

二、使用novoda 插件上传到bintray

使用 com.novoda:bintray-release 这个插件可以比较简单的把aar(包含依赖的三方aar) 上传到bintray,这种上传在pom中有依赖的三方aar的配置,使用时不用额外引入三方aar

project 级别的build.gradle中的dependencies 下添加依赖

classpath 'com.novoda:bintray-release:0.9.2'

完整配置

buildscript {
    repositories {
        google()
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.6.2'
        classpath 'com.novoda:bintray-release:0.9.2'
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        maven { url 'https://jitpack.io' }
    }
    //编码 ,javadoc 检查忽略
    tasks.withType(Javadoc) {
        options.addStringOption('Xdoclint:none', '-quiet')
        options {
            encoding 'UTF-8'
            charSet 'UTF-8'
        }
    }

    gradle.projectsEvaluated {
        tasks.withType(JavaCompile) {
            options.compilerArgs << "-Xlint:unchecked" << "-Xlint:deprecation"
        }
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

需要上传的module下新建upload.gradle文件,名字随意起,内容如下
//引入novoda 插件,这行也可以放在对应module 的build.gradle文件的顶部引入
//这里方便复用,放在了upload.gradle中

apply plugin: 'com.novoda.bintray-release'

//这几个定义也可以放在 各自module下的 gradle.properties文件中
def GROUP_ID = "com.components"
def ARTIFACT_ID = "common"
def VERSION = "1.0.0"

//添加
publish {
    userOrg = 'jingzhanwu'//  bintray.com用户名
    groupId = GROUP_ID //jcenter上的路径
    artifactId = ARTIFACT_ID //项目名称
    publishVersion = VERSION //版本号
    desc = 'Oh hi, this is a components library for a android.' //描述,不重要
    website = 'https://github.com/xxx/xxx' //网站,不重要;尽量模拟github上的地址,例如我这样的;当然你有地址最好了
}

在对应module的build.gradle底部引入 upload.gradle文件

一般是在文件底部引入

apply from: "upload.gradle"

开始打包上传

在studio 的命令行窗口 Terminal 中执行上传命令

gradlew clean build bintrayUpload -PbintrayUser=zhangsan -PbintrayKey=zhangsanKey -PdryRun=false

说明:
gradlew clean build bintrayUpload:执行一个gradlew任务,先clean,再build,最后执行bintrayUpload
-PbintrayUser:指定 你bintray的用户名
-PbintrayKey: 指定 你bintray的ApiKey 值,这个值可以在自己bintray中查看
-PdryRun:一般指定为false

三、本地指定目录打包生成aar

对应module 下新建upload_local.gradle文件,名字随意起,内容如下

//引入maven插件
apply plugin: 'maven'

//这几个定义也可以放在 各自module下的 gradle.properties文件中
def GROUP_ID = "com.jzw"
def ARTIFACT_ID = "components"
def VERSION = "1.0.0"

uploadArchives {
    repositories.mavenDeployer {
        // 配置本地仓库路径,项目根目录下的repository目录中
        repository(url: uri('../repository')) {
            pom.groupId = GROUP_ID  //唯一标识(通常为模块包名,也可以任意)
            pom.artifactId = ARTIFACT_ID  //项目名称(通常为类库模块名称,也可以任意)
            pom.version = VERSION  // 版本号
        }

        //解决生成的pom 没有groupId 和版本号的问题
        pom.whenConfigured { pom ->
            pom.dependencies.forEach { dep ->
                if (dep.getVersion() == "unspecified") {
                    println("--modify the dependenies module in pom.xml--->>" + dep.getArtifactId())
                    dep.setGroupId(GROUP_ID)
                    dep.setVersion(VERSION)
                }
            }
        }
    }
}

说明:

repository(url: uri('../repository')) :

这里指定aar生成的路劲为当前module上一级的repository,也就是工程的根目录下的repository目录,你也可以指定到其他任意的目录

对应module下的build.gradle文件中引入upload_local.gradle

一般在文件尾部引入

apply from: "upload_local.gradle"

在studio右侧的Gradle栏中找到对应module下 upload 下的uploadArchives任务,并双击执行它

等待执行完毕,没有出错的情况下会在指定的本地目录下生成对应版本的 aar以及pom文件

使用本地aar

工程的gradle文件中添加本地maven的url,即上面repository 指向的本地目录,之后使用implamentation引入即可

project 级别的gradle下指定aar目录

maven { url 'F:\\AndroidLibrary\\repo' }

module中引入

implementation('com.jzw:components:1.0.0') { transitive = true }

四、Android aar 拷贝到sdk一起打包成新的aar

1、需要将一个aar包与项目产生的aar包合并成一个,其中项目是源码
2、项目是源码

解压依赖aar

解压aar,利用build,gradle

//很重要,因为解压后如果copy资源文件到raw里,这时R文件已经编译了,所以要在R文件编译之前执行此操作
tssks.withType(com.android.build.gradle.tasks.NdkCompile) {
      compileTask -> compileTask.dependsOn(unzipAAR)
}
task unzipAAR(type: Exec) {
    commandLine 'unzip', '-o',    file("libs/xxxx.aar").getAbsolutePath(), '-d', file('MyAAR')
}

unzipAAR.doLast {
       copy {
           from 'MyAAR/res/raw'
           into 'src/main/res/raw'
       }
      
        copy {
          from 'MyAAR/classes.jar'
          into 'libs/jars/'
          rename { String fileName -> "xxxx.jar"}
      }

//这里libs文件夹下只有一个jar
        copy {
          from 'MyAAR/libs/'
          into 'libs/jars/'
          rename { String fileName -> "xxxx.jar"}
    }
}
tasks.withType(JavaCompile) {
   compileTask -> compileTask.dependsOn unzipAAR
}
如果有ndk编译,so的copy动作要放在ndk之后
task copyJNIso (type: Copy) {
    from 'MyAAR/jni'
    into 'src/main/libs'
}

tasks.withType(JavaCompile) {
   compileTask -> compileTask.dependsOn copyJNIso 
}

copyJNIso .mustRunAfter 'ndkBuild'
清除操作

创建一个makeclean.sh文件,可以是libs/makeclean.sh
build.gradle文件还要添加

task makeClean(type: Exec) {
    executable 'sh'
    args "libs/makeclean.sh"
}

clean.dependsOn 'makeClean'

makeclean.sh
···

!/bin/sh
rm -rf MyAAR
rm -rf libs/jars/xxxx.jar
rm-rf libs/jars/xxxxx.jar
rm -rf src/main/res/raw

···

你可能感兴趣的:(Android SDK开发之 aar 打包攻略)