Android预置Apk方法

本文详细介绍如何在Android系统中预置各种类型的APP,包括有源码和无源码的APK,以及如何配置使APP可卸载或不可卸载等。通过具体的步骤指导开发者完成系统应用的集成。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

因为工作需要,经常要开发和合入系统App,所以在此开篇作为收集和记录Android合入系统应用的方法,以备日后查阅。

一、预置apk方法

Case 1:如何将带源码的APK预置进系统

  1. 在 packages/apps 下面以需要预置的 APK的 名字创建一个新文件夹,以预置一个名为Test的APK 为例
  2. 将 Test APK的Source code 拷贝到 Test 文件夹下,删除 /bin 和 /gen 目录
  3. 在 Test 目录下创建一个名为 Android.mk的文件,内容如下:
LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)

LOCAL_MODULE_TAGS := optional
LOCAL_SRC_FILES := $(call all-subdir-java-files)

LOCAL_PACKAGE_NAME := Test
include $(BUILD_PACKAGE)
  1. 打开文件 device\mediatek\common\device.mk,将 Test 添加到 PRODUCT_PACKAGES 里面。
PRODUCT_PACKAGES += Test
  1. 重新 build 整个工程

Case 2:如何将无源码的 APK 预置进系统?

  1. 在 packages/apps 下面以需要预置的 APK 名字创建文件夹,以预置一个名为Test的APK为例
  2. 将 Test.apk 放到 packages/apps/Test 下面
  3. 在 packages/apps/Test 下面创建文件 Android.mk,文件内容如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
# Module name should match apk name to be installed
LOCAL_MODULE := Test
LOCAL_MODULE_TAGS := optional

LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)

LOCAL_PREBUILT_JNI_LIBS:= \
@lib/armeabi/libtest.so \
@lib/armeabi/libtest2.so

LOCAL_CERTIFICATE := PRESIGNED
include $(BUILD_PREBUILT)

若无so,删除LOCAL_PREBUILT_JNI_LIBS
若有so,使用LOCAL_PREBUILT_JNI_LIBS列出所有so的路径,不要忘记使用@。@标识符会将apk中的so抽离出来build进apk同级目录下的lib文件夹中

若apk支持不同cpu类型的so,针对so的部分的处理:

Ifeq ($(TARGET_ARCH),arm)
LOCAL_PREBUILT_JNI_LIBS := \
@lib/armeabi-v7a/xxx.so\
@ lib/armeabi-v7a/xxxx.so
else ifeq ($(TARGET_ARCH),x86)
LOCAL_PREBUILT_JNI_LIBS := \
@lib/x86/xxx.so
else ifeq ($(TARGET_ARCH),arm64)
LOCAL_PREBUILT_JNI_LIBS := \
@lib/armeabi-v8a/xxx.so
…

即将和TARGET_ARCH对应的so抽离出来

  1. 打开文件 device\mediatek\common\device.mk
    将 Test 添加到 PRODUCT_PACKAGES 里面。
    PRODUCT_PACKAGES += Test
  2. 重新 build 整个工程

tip
如果App使用System Level的permission,需要預置到/system/priv-app底下 (原在/system/app)。
修改Android.mk,增加LOCAL_PRIVILEGED_MODULE := true,以声明app需要放在/system/priv-app下。

Case 3:如何预置APK使得用户可以卸载,恢复出厂设置时不能恢复?

  1. 在 packages/apps 下面以需要预置的 APK 名字创建文件夹,以预置一个名为Test的APK为例
  2. 将 Test.apk 放到 packages/apps/Test 下面
  3. 在 packages/apps/Test 下面创建文件 Android.mk,文件内容如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

# Module name should match apk name to be installed
LOCAL_MODULE := Test
LOCAL_MODULE_TAGS := optional

LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
# LOCAL_PRIVILEGED_MODULE := true
LOCAL_MODULE_PATH := $(TARGET_OUT_DATA_APPS)

LOCAL_CERTIFICATE := PRESIGNED
include $(BUILD_PREBUILT)
  1. 打开文件 device\mediatek\common\device.mk
    将 Test 添加到 PRODUCT_PACKAGES 里面。
PRODUCT_PACKAGES += Test
  1. 重新 build 整个工程
    注意:这个比不能卸载的多了一句
LOCAL_MODULE_PATH := $(TARGET_OUT_DATA_APPS)

Case 4:如何预置APK使得用户可以卸载,并且恢复出厂设置时能够恢复?

  1. 在 vendor\mediatek\proprietary\binary\3rd-party\free下面以需要预置的 APK 名字创建文件夹,以预置一个名为Test的APK为例
  2. 将Test.apk 放入vendor\mediatek\proprietary\binary\3rd-party\free\Test下面
  3. 在vendor\mediatek\proprietary\binary\3rd-party\free\Test 下面创建文件 Android.mk,文件内容如下:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

# Module name should match apk name to be installed
LOCAL_MODULE := Test
LOCAL_MODULE_TAGS := optional
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk

LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
LOCAL_CERTIFICATE := PRESIGNED

LOCAL_MODULE_PATH := $(TARGET_OUT)/vendor/operator/app
include $(BUILD_PREBUILT)
  1. 打开文件device\mediatek\common\device.mk
    将 Test 添加到 PRODUCT_PACKAGES 里面。
PRODUCT_PACKAGES += Test
  1. 然后重新build整个工程

若需要apk作为32bit的apk运行,则需要在Android.mk中定义

LOCAL_MULTILIB :=32

二、Android.mk文件参数说明

LOCAL_MODULE_TAGS := optionaloptional,指该模块在所有版本下都编译
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk获取目录下的java文件
LOCAL_PACKAGE_NAME := Test包名
LOCAL_CERTIFICATE := platform签名,PRESIGNED表示保留apk文件之前的签名,platform是对apk重新进行签名
LOCAL_PROGUARD_ENABLED := disabled不要使用代码混淆的工具进行混淆

转载信息:
作者:烟雨随风
链接:https://www.jianshu.com/p/9af0a34d3eed
來源:简书

### 如何在 Android 系统中预置 APK 文件 在 Android 系统中预置 APK 的过程涉及多个步骤技术细节,主要包括编译环境配置、APK 预置方式的选择以及权限管理等内容。 #### 方法概述 通常有四种主要方法可以用于将应用程序作为系统级应用预置Android 中[^2]: 1. **通过 `PRODUCT_COPY_FILES` 将 APK 复制到 `/system/priv-app` 或 `/system/app`** 这是最常见的方法之一。开发者可以通过修改设备的 `BoardConfig.mk` 或其他构建脚本文件,在编译过程中自动复制目标 APK 到指定目录。 ```makefile PRODUCT_COPY_FILES += \ path/to/MirrorService.apk:$(TARGET_COPY_OUT_SYSTEM)/app/MirrorService/MirrorService.apk ``` 此种方法适用于需要简单集成的应用程序,并且能够确保其成为系统的特权应用(如果放置于 `/system/priv-app` 下)。 2. **利用 `Android.mk` 构建模块定义** 开发者可以在项目的根目录下创建一个名为 `Android.mk` 的 Makefile 脚本来描述如何处理该 APK。例如: ```makefile LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := MirrorService LOCAL_MODULE_CLASS := APPS LOCAL_MODULE_TAGS := optional LOCAL_BUILT_MODULE_STEM := package.apk LOCAL_MODULE_SUFFIX := .apk LOCAL_PRIVILEGED_MODULE := true LOCAL_CERTIFICATE := platform LOCAL_SRC_FILES := $(LOCAL_MODULE).apk include $(BUILD_PREBUILT) ``` 上述代码片段展示了如何声明并安装一个预先打包好的 APK 至系统分区中的具体实现。 3. **调整文件系统权限** 如果某些特定路径下的资源或数据包需要特殊访问控制,则可能还需要同步更新 libcutils 库内的 fs_config 定义部分来匹配新的需求。比如新增加了一个软件包存储位置时就需要像下面这样操作[^3]: ```cpp diff --git a/libcutils/fs_config.cpp b/libcutils/fs_config.cpp ... +{ 00400, AID_ROOT, AID_ROOT, 0, "system/etc/software_pack" }, ``` 修改后的条目会赋予新加入子目录恰当的安全属性以便后续正常使用。 4. **自定义 ROM 并重新刷机** 对于完全掌控整个固件镜像的情况来说,可以直接编辑对应厂商定制版本源码树里的相关组件完成更深层次改动后再生成最终可烧录映像文件上传至终端设备执行刷新动作即可达成目的。 --- ### 示例代码展示 以下是基于第二种方法的一个完整例子说明如何把现有的第三方 apk 整合进入官方开源项目里头去: ```bash # 假设当前工作区位于 vendor/example/prebuilt/ mkdir -p app/com.example.mirrorservice cp /path/to/existing/mirrorservice-release-signed-aligned.apk ./com.example.mirrorservice/MirrorService.apk nano Android.mk ``` 接着填写如下内容进去保存退出: ```makefile LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := MirrorService LOCAL_MODULE_OWNER := example LOCAL_MODULE_TAGS := optional LOCAL_MODULE_CLASS := APPS LOCAL_DEX_PREOPT := false LOCAL_CERTIFICATE := PRESIGNED LOCAL_MODULE_SUFFIX := .apk LOCAL_PRODUCT_MODULE := true LOCAL_PRIVATE_PLATFORM_APIS := true LOCAL_OVERRIDES_PACKAGES := LOCAL_REQUIRED_MODULES := LOCAL_MULTILIB := both LOCAL_MODULE_TARGET_ARCH := arm64 LOCAL_SRC_FILES_64 := com.example.mirrorservice/MirrorService.apk LOCAL_MODULE_PATH_64 := $(PRODUCT_OUT)/system_ext/app/MirrorService/ include $(BUILD_PREBUILT) ``` 最后记得同步更新 product 分配清单文档 ProductDefinition.xml 添加必要的依赖项支持从而顺利触发自动化流程组装环节[^2]. --- ### 注意事项 - 所有的 APK 必须经过签名才能被正确识别为合法组件加载运行起来[^1]。 - 当涉及到敏感功能调用时务必确认已授予适当级别的授权许可以免引发异常崩溃现象发生。 - 不同品牌机型可能存在差异化的适配策略因此建议优先参照目标平台官方指导手册为准绳开展实际作业活动[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值