开发者

Android Studio打包 aar实现步骤示例详解

目录
  • 引言
    • 一、不包含第三方依赖的打包
    • 二、包含第三方依赖的打包
    • 三、补充说明

引言

演示Demo中创建了两个 Library Module,其中A不包含第三方依赖库,B包含;笔者将在下面介绍两种类型的打包,并在app module中引用

项目目录

Android Studio打包 aar实现步骤示例详解

一、不包含第三方依赖的打包

如果需要打包的module中没有引入任何的第三方依赖库,或者打包出来的aar在其他项目中并不需要用到依赖的三方库,可以使用该方式打包;否则请看下面 包含第三方依赖的打包

1. android Studio 打开右侧的 Gradle 面板,选择需要打包的module —> Tasks —> build, 双击 assemble

assemble 打包 aar

Android Studio打包 aar实现步骤示例详解

2. Build Successed 之后,将会在module的build/outputs/aar目录下生成 debug 和 release 两个版本的 aar包

Android Studio打包 aar实现步骤示例详解

3. 在 app module 中引用 libraryA,先将刚才生成的aar拷贝到 app module 的 libs目录下

Android Studio打包 aar实现步骤示例详解

4. 在打开app module 的 build.gradle, 添加如下红色框中内容

添加 aar 依赖

Android Studio打包 aar实现步骤示例详解

repositories  {
    flatDir{ dwww.devze.comirs 'libs'  }
}
compile(name: 'librarya-debug', ext: 'aar')

二、包含第三方依赖的打包

如果library中引用了第三方的依赖包,再采用上面的方式,编译时将会提示说一些第三方的类文件找不到了。所以此时需编程客栈要将library打成本地或远程的aar仓库,然后在项目中引用;

1. 打开 library 的 build.gradle 文件,在最外层加入如下内容

apply plugin: 'maven'
// 省略其他配置
uploadArchives{
    repositories.mavenDeployer{
        // Ubuntu本地仓库路径, Windows 为(url:"file://D://***/***/***/")
        repository(url:"file:/home/jinyx/develop/other/")
        // 唯一标识
        pom.groupId = "com.jinyx"
        // 项目名称
        pom.artifactId = "libraryB"
        // 版本号
vfACBeT        pom.version = "1.0"
    }
}

2. 同样的,打开Android Studio右侧的Gradle面板,双击 module下面的 Tasks/upload/uploadArchives

上传仓库

Android Studio打包 aar实现步骤示例详解

3. BUILD SUCCESSFUL之后,本地刚才配置的仓库路径中将会生成aar相关的文件

生成本地aar仓库

Android Studio打包 aar实现步骤示例详解

4. 在app module中引用aar,首先在根目录的 build.gradle 的仓库配置中加入本地仓库地址,然后在app module 的bulid.gradle 中添加 项目依赖

// 添加到 root 的 build.gradle
maven{
    url 'file:/home/jinyx/develop/other/'
}
// 添加到 app 的 build.gradle,注意名字规则和上面配置本地仓库之间的关联
implementation 'com.jinyx:libraryB:1.0'

远程仓库的就不说了,只是将上面配置的仓库地址 换成线上的

三、补充说明

  • 打包的module需要是 library,如果是 application的module,需要将 build 配置中的 apply plugin: 'com.android.application' 替换成 apply plugin: 'com.android.library',并且去掉applicationId
  • 打包的module下的清单文件,application标签下的android:name、android:roundIcon、android:icon三个属性需要移除,避免和引用的项目中的清单文件产生冲突。同样的,由于aar将资源文件也打包在里面,所以需要避免和引用的项目重名,造成资源冲突
  • 如果是打包的app模块,一般会有自定义的Application,用于一些SDK的初始化等操作,但是上面说到android:nahttp://www.devze.comme属性需要移除,所以引用aar的项目的application,需要继承aar中原先的application,或者是实现里面的初始化等内容
  • 上面提到,application模块打包成aar时,需要移除applicationId,所以问题来了;Android7.0对文件访问的限制,需要添加 File Provider,其中使用差值表达式引用了applicationId
<provider
    android:name="android.support.v4.content.FileProvider"
    android:authorities="${applicationId}.vfACBeTfile.provider"
    android:grantUriPermissions="true">
    <meta-data
        android:name="android.support.FILE_PROVIDER_PATHS"
        android:resource="@XML/boxing_file_provider" />
</provider>

如果 build.gradle 中没有定义 applicationId,那么编译时会把 AndroidManfest 中的packageName 作为 applicationId

以上就是Android Studio 打包 aar的详细内容,更多关于Android Studio 打包 aar的资料请关注编程客栈(www.devze.com)其它相关文章!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜