编写Android.mk / Android.bp 引用三方 jar 包,aar包,so 库

本文详细介绍了如何在Android.mk和Android.bp文件中引入第三方jar包、aar包、so库,以及特许白名单权限xml的处理方法,适用于AndroidStudio项目向AOSP源码迁移的开发者。
摘要由CSDN通过智能技术生成

一.前言

        在Android10之后,所有项目工程中,官方推荐使用Android.bp去编译构建,以前使用Android.mk构建的项目随着版本迭代升级,慢慢需要变更为Android.bp, 两者的语法都需要去了解并熟练使用。 笔者之前写过Android.mk的语句介绍,里面有介绍每句代码的含义编写Android.mk把Android studio项目编译到AOSP源码中

后来也总结过 Android.bp基本用法: Android.bp 语法和使用   比较基础,也是在项目中运用到了就记录下来。

本篇文章写的是在项目工程中编写Android.mk和 Android.bp 文件,引入第三方的jar包,aar包, so库,引入特许白名单权限xml文件。

二. Android.mk 编写

1. 引入jar包

比如,我们当前目录下的 libs 有okhttp-3.4.11.jar 包,我想引用它

需要两个步骤

第一步, 声明我们 jar 包所在的目录,我的是AndroidStudio工程目录,所以jar包的路径是app/libs/okhttp-3.4.11.jar

LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := okhttp3:app/libs/okhttp-3.4.11.jar

这行代码的意思大概可以理解成这样,声明一个变量 okhttp3,它的 value 是 app/libs/okhttp-3.4.11.jar

include $(CLEAR_VARS)
LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := okhttp3:app/libs/okhttp-3.4.11.jar \
                                        okio:app/libs/okio-1.9.0.jar
include $(BUILD_MULTI_PREBUILT)  #这里是多个jar包预编译

第二步. 引用我们声明 jar 包的变量 引用我们上面声明的 okhttp3

LOCAL_STATIC_JAVA_LIBRARIES := okhttp3

LOCAL_STATIC_JAVA_LIBRARIES := okhttp3 \
                               okio

2. 引入aar包

第一步:先声明 aar 包的位置

include $(CLEAR_VARS)
LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := \
   lottie-2.8.0:app/libs/lottie-2.8.0.aar
include $(BUILD_MULTI_PREBUILT)

第二步:引用声明的 aar 变量 lottie-2.8.0

LOCAL_STATIC_JAVA_AAR_LIBRARIES := lottie-2.8.0

第三步:添加引用的 aar 包资源

LOCAL_AAPT_FLAGS := \
  --auto-add-overlay \
  --extra-packages com.airbnb.lottie

3. 引入so库

假如我们当前目录下的 lib 目录下 有 armeabi-v7a,arm64-v8a 目录,里面分别有 libaes-jni.so, 如果我们在编译 apk 的时候,想把这些 so 库 打包进去,在 mk 文件中要怎样配置呢?

第一步,直接在 mk 文件中配置以下内容,预编译处理

include $(CLEAR_VARS)
LOCAL_MODULE_TAGS := optional
#后缀
LOCAL_MODULE_SUFFIX := .so
#模块名
LOCAL_MODULE := libaes-jni
#编译到system/libs/目录下
LOCAL_MODULE_CLASS := SHARED_LIBRARIES

#另外一种写法,根据平台arm  arm64 去选择编译对应的so文件
#ifeq ($(strip $(TARGET_ARCH)),arm64)
#LOCAL_SRC_FILES :=app/libs/arm64-v8a/libaes-jni.so
#else ifeq ($(strip $(TARGET_ARCH)),arm)
#LOCAL_SRC_FILES :=app/libs/armeabi-v7a/libaes-jni.so
#endif

#arm arm64都编译
LOCAL_SRC_FILES_arm :=app/libs/armeabi-v7a/libaes-jni.so
LOCAL_SRC_FILES_arm64 :=app/libs/arm64-v8a/libaes-jni.so
LOCAL_MODULE_TARGET_ARCHS:= arm arm64
LOCAL_MULTILIB := both
include $(BUILD_PREBUILT)

第二步: 引用目标 so 库

在include $(CLEAR_VARS) 和 include $(BUILD_PACKAGE) 之间添加以下内容

LOCAL_REQUIRED_MODULES := libaes-jni


#如果你写这句话 把这个libaes-jni.so 同时也打包 放在out/target/产品名路径/你的apk具体路径下/lib/#目录中
#LOCAL_JNI_SHARED_LIBRARIES := libaes-jni

备注:

LOCAL_MODULE_CLASS:(prebuilt)标识了所编译模块最后放置的位置,如果不指定,不会放到系统中。
LOCAL_MODULE_CLASS := ETC 放于system/etc目录
LOCAL_MODULE_CLASS := EXECUTABLES 放于/system/bin目录
LOCAL_MODULE_CLASS := SHARED_LIBRARIES 放在/system/lib目录
LOCAL_MODULE_CLASS := JAVA_LIBRARIES
LOCAL_MODULE_CLASS := STATIC_LIBRARIES
LOCAL_MODULE_CLASS := APPS 放在/system/app目录
 

LOCAL_JNI_SHARED_LIBRARIES变量主要是用在JNI的编译中,如果你要在你的Java代码中引用JNI中的共享库*.so,此变量就是共享库的名字。
那么你要注意的一点是:在你的Project根目录下的Android.mk中要定义此变量用来引用你要使用的JNI中的共享库*.so  定义了要包含的so库文件的名字,如果程序没有采用jni,就不需要


LOCAL_JNI_SHARED_LIBRARIES := libxxx    这样在编译的时候,NDK自动会把这个libxxx打包进apk; 放在out/target/产品名路径/你的apk具体路径下/lib/目录中

LOCAL_REQUIRED_MODULES 指定模块运行所依赖的模块(模块安装时将会同步安装它所依赖的模块)

4. 引入特许白名单权限xml

com.test.mtk.xml 内容:

<?xml version="1.0" encoding="utf-8"?>
<permissions>
    <privapp-permissions package="com.test.mtk">
        <permission name="android.permission.MASTER_CLEAR" />
    </privapp-permissions>
</permissions>

第一步:预编译处理


######预编译priv-app 权限,输出路径为system/etc/permissions###########
# Permissions pre-grant
include $(CLEAR_VARS)
LOCAL_MODULE := com.test.mtk.xml
LOCAL_MODULE_CLASS := ETC
LOCAL_MODULE_PATH := $(TARGET_OUT_ETC)/permissions
LOCAL_SRC_FILES := $(LOCAL_MODULE)
include $(BUILD_PREBUILT)

第二步:指定app运行所依赖的模块


######编译priv-app 权限到apk中###########
LOCAL_REQUIRED_MODULES := com.test.mtk.xml

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值