Android 浅度解析:系统框架层修改,编译,推送相关操作

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: Android 浅度解析:系统框架层修改,编译,推送相关操作

在Android系统开发过程中,我们经常需要对系统框架层进行修改。本文将详细介绍如何编译和推送这些修改,以及如何进行一些常见的操作。

1. Android系统框架层简介

Android系统框架层是Android系统的核心层,提供了各种服务和API给上层的应用和模块。它包含Java类、资源文件、native代码和API签名等,这些组件会被打包或链接到一些文件中,如framework.jarframework-res.apklibandroid_servers.soselinux_policy等。这些文件在系统启动时被加载到内存中,如果我们想要对它们进行修改,那么我们需要使用一些特定的编译和推送方法,让我们的修改生效。

2. 常见文件类型的编译和推送

根据修改的文件类型和内容,我们可以选择不同的编译和推送方法。

2.1 framework.jar

framework.jar是包含了Android系统框架层Java类的压缩文件。如果只修改了该文件,可以按照以下步骤操作:

# 启动编译工具
source build/envsetup.sh
# 编译framework.jar文件
make framework
# 获取设备的root权限和可写权限
adb root && adb remount
# 将编译后的framework.jar推送到设备
adb push out/target/product/<device>/system/framework/framework.jar /system/framework/
# 删除一些缓存文件
adb shell rm -rf /data/dalvik-cache /cache/dalvik-cache
# 同步数据并重启设备
adb shell sync && adb reboot

注意:这种方法不能用于修改framework.jar文件中的资源文件、native代码,或者API签名。

2.2 framework-res.apk

framework-res.apk是包含了Android系统框架层资源文件的压缩文件。修改该文件后,需要按照以下步骤重新编译并推送到设备:

# 启动编译工具
source build/envsetup.sh
# 编译framework-res.apk文件
make FrameworkRes
# 获取设备的root权限和可写权限
adb root && adb remount
# 将编译后的framework-res.apk推送到设备
adb push out/target/product/<device>/system/framework/framework-res.apk /system/framework/
# 同步数据并重启设备
adb shell sync && adb reboot

2.3 libandroid_servers.so

libandroid_servers.so是包含了Android系统框架层服务层native代码的动态链接库文件。修改该文件后,需要按照以下步骤重新编译并推送到设备:

# 启动编译工具
source build/envsetup.sh
# 编译libandroid_servers.so库文件
make libandroid_servers
#
获取设备的root权限和可写权限
adb root && adb remount
# 将编译后的libandroid_servers.so推送到设备
adb push out/target/product/<device>/system/lib/libandroid_servers.so /system/lib/
# 同步数据并重启设备
adb shell sync && adb reboot

2.4 selinux_policy

selinux_policy是包含了安全增强型Linux(SELinux)策略的文件。修改该文件后,需要按照以下步骤重新编译并推送到设备:

# 启动编译工具
source build/envsetup.sh
# 编译selinux_policy文件
make selinux_policy
# 获取设备的root权限和可写权限
adb root && adb remount
# 将编译后的selinux_policy推送到设备
adb push out/target/product/<device>/root/sepolicy /
# 同步数据并重启设备
adb shell sync && adb reboot

2.5 API签名

API签名是一些定义了Android系统框架层API的文件,如current.txtaidl文件。修改这些文件后,需要重新编译整个系统,并刷入新的镜像。这是因为API签名会影响到其他模块或应用的兼容性,如果只修改部分文件,可能会导致错误或异常。可以按照以下步骤编译和刷入新的镜像:

# 启动编译工具
source build/envsetup.sh
# 选择设备型号和编译模式
lunch <device>-userdebug
# 更新API并编译整个系统
make update-api && make -j24
# 刷入新的镜像,并清除用户数据
fastboot flashall -w

3. 开启开发者选项和USB调试

在Android 11上,我们可以使用无线ADB来部署和调试我们的应用,而不需要通过USB连接设备。但是,我们仍然需要在设备上开启开发者选项和USB调试。

要开启开发者选项,我们需要在设置中找到设备的版本号选项,并连续点击七次,直到看到您现在是开发者的提示。然后返回上一屏,就可以看到开发者选项了。

要开启USB调试,我们需要在开发者选项中找到USB调试选项,并打开它。这样,Android Studio和其他SDK工具就可以识别我们通过USB或无线连接的设备了。

4. 选择编译模块

每个模块都有对应的bp或者mk文件,如果没有就往上层路径查找,对应模块名字(用grep -rnws --include='*.bp' 'name:'也可以查找),如果不清楚,也可以用绝对路径进行编译。

编译指令如下:

命令 解释 例子
mm 对应模块名字编译,但是不编译依赖模块 mm Settings
mmm 编译指定目录下的模块,但是不编译依赖模块 mmm packages/apps/Settings
mma/make 编译指定目录下的模块,包含依赖模块 mma packages/apps/Settings Settinglib
mmma 编译指定目录下的所有模块,包含依赖模块 mmma packages/apps

5. 替换系统文件

5.1 替换apk

以SystemUI为例:

  • 编译:mm SystemUI ,生成路径:/out/target/product/项目名字/product/priv-app/SystemUI/SystemUI.apk
  • 替换:adb push /out/target/product/项目名字/product/priv-app/SystemUI/SystemUI.apk /product/priv-app/SystemUI/SystemUI.apk ,然后重启即可生效

5.2 编译framework

  • 编译:make framework-minus-apex -j8 (-j8表示启动8核快速编译)
  • 替换:
adb root;adb remount;
adb push out/target/product/项目名字/system/framework/framework.jar system/framework/;
adb push out/target/product/项目名字/system/framework/arm/* system/framework/arm/;
adb push out/target/product/项目名字/system/framework/arm64/* system/framework/arm64/;
adb reboot

5.3 编译selinux

selinux分为system和vendor,一般我们只修改vendor下面,但是系统会整合system和vendor,所以我们不用管,一起编译替换即可。

  • 编译:make selinux_policy
  • 替换:一般生成在下面的路径,只有要都替换,同样,重启生效
adb push out/target/product/项目名字/system/system_ext/etc/selinux/* system_ext/etc/selinux/;
adb push out/target/product/项目名字/vendor/etc/selinux/* /vendor/etc/selinux/;
adb push out/target/product/项目名字/system/etc/selinux/* /system/etc/selinux/;
adb push out/target/product/项目名字/system/product/etc/selinux/* /product/etc/selinux/

5.4 编译services

  • 编译:mm services
  • 替换:
adb root;adb remount;adb push out/target/product/项目名字/system/framework/services.jar /system/framework/;
adb push out/target/product/项目名字/system/framework/oat/arm64/services.* /system/framework/oat/arm64/;adb shell sync;adb reboot

5.5 编译feature

方式1:参考系统路径下的方式frameworks/native/data/etc/自定义.xml

<permissions>
    <feature name="com.google.android.feature.xxxx" />
</permissions>

mk文件中添加即可,重启系统会自动解析该路径文件:

PRODUCT_COPY_FILES += frameworks/native/data/etc/自定义.xml$(TARGET_COPY_OUT_VENDOR)/etc/permissions/自定义.xml

方式2:自定义文件可以

随便放,通过mk文件的方式编译,生成到指定路径

LOCAL_PATH := $(my-dir)
########################
include $(CLEAR_VARS)
LOCAL_MODULE := 自定义.xml
LOCAL_MODULE_TAGS := optional
LOCAL_MODULE_CLASS := ETC
# This will install the file in /system/etc/permissions
LOCAL_MODULE_PATH := $(TARGET_OUT_ETC)/permissions
LOCAL_SRC_FILES := $(LOCAL_MODULE)
include $(BUILD_PREBUILT)

添加到系统编译文件中去

PRODUCT_PACKAGES += 自定义.xml

一般rc文件,和脚本文件都是可以直接push替换的,不需要编译。

6. 使用ninja编译

关于android 10及以上单编译模块速度慢的问题主要是因为在mm build的过程中去调用了一些方法需要搜索所有的BP和android.mk和生成新的ninja文件导致编译过慢。我们可以在build/make/envsetup.sh新增一个singleninja函数

function singleninja()
{
    local cmdline="time prebuilts/build-tools/linux-x86/bin/ninja -v -d keepdepfile $@ -f out/combined-项目名字.ninja -w dupbuild=warn"
    echo $cmdline
    $cmdline
}

添加完. build/envsetup.sh就可以生效。比如说singleninja Settings就会发现很快就编译好了。

7. 编译init

  • 编译:make init或者上面的singleninja init
  • 替换:adb push out/target/product/productname/system/bin/init system/bin/init ;adb reboot即可

8. 编译framework-res

修改framework/base/core/res/下面的字符串或者config等配置的时候,就可以单独编译这个替换。

  • 编译:mm framework-res, make framework-res或者上面的singleninja framework-res
  • 替换:adb push out/target/product/项目/system/framework/framework-res.apk system/framework/framework-res.apk

以上就是对Android系统框架层修改及其相关操作的详细介绍。希望这篇文章对你有所帮助,如果有任何疑问,欢迎留言交流。

参考:

相关文章
|
23天前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
46 15
Android 系统缓存扫描与清理方法分析
|
5天前
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
30 3
|
14天前
|
算法 JavaScript Android开发
|
16天前
|
安全 搜索推荐 Android开发
揭秘安卓与iOS系统的差异:技术深度对比
【10月更文挑战第27天】 本文深入探讨了安卓(Android)与iOS两大移动操作系统的技术特点和用户体验差异。通过对比两者的系统架构、应用生态、用户界面、安全性等方面,揭示了为何这两种系统能够在市场中各占一席之地,并为用户提供不同的选择。文章旨在为读者提供一个全面的视角,理解两种系统的优势与局限,从而更好地根据自己的需求做出选择。
42 2
|
25天前
|
安全 搜索推荐 Android开发
深入探索安卓与iOS系统的差异及其对用户体验的影响
在当今的智能手机市场中,安卓和iOS是两大主流操作系统。它们各自拥有独特的特性和优势,为用户提供了不同的使用体验。本文将深入探讨安卓与iOS系统之间的主要差异,包括它们的设计理念、用户界面、应用生态以及安全性等方面,并分析这些差异如何影响用户的使用体验。
|
24天前
|
安全 搜索推荐 Android开发
揭秘iOS与Android系统的差异:一场技术与哲学的较量
在当今数字化时代,智能手机操作系统的选择成为了用户个性化表达和技术偏好的重要标志。iOS和Android,作为市场上两大主流操作系统,它们之间的竞争不仅仅是技术的比拼,更是设计理念、用户体验和生态系统构建的全面较量。本文将深入探讨iOS与Android在系统架构、应用生态、用户界面及安全性等方面的本质区别,揭示这两种系统背后的哲学思想和市场策略,帮助读者更全面地理解两者的优劣,从而做出更适合自己的选择。
|
1月前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
82 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
1月前
|
消息中间件 中间件 数据库
NServiceBus:打造企业级服务总线的利器——深度解析这一面向消息中间件如何革新分布式应用开发与提升系统可靠性
【10月更文挑战第9天】NServiceBus 是一个面向消息的中间件,专为构建分布式应用程序设计,特别适用于企业级服务总线(ESB)。它通过消息队列实现服务间的解耦,提高系统的可扩展性和容错性。在 .NET 生态中,NServiceBus 提供了强大的功能,支持多种传输方式如 RabbitMQ 和 Azure Service Bus。通过异步消息传递模式,各组件可以独立运作,即使某部分出现故障也不会影响整体系统。 示例代码展示了如何使用 NServiceBus 发送和接收消息,简化了系统的设计和维护。
48 3
|
15天前
|
安全 搜索推荐 程序员
深入探索Android系统的碎片化问题及其解决方案
在移动操作系统的世界中,Android以其开放性和灵活性赢得了广泛的市场份额。然而,这种开放性也带来了一个众所周知的问题——系统碎片化。本文旨在探讨Android系统碎片化的现状、成因以及可能的解决方案,为开发者和用户提供一种全新的视角来理解这一现象。通过分析不同版本的Android系统分布、硬件多样性以及更新机制的影响,我们提出了一系列针对性的策略,旨在减少碎片化带来的影响,提升用户体验。
|
15天前
|
安全 Android开发 iOS开发
深入探索iOS与Android系统的差异性及优化策略
在当今数字化时代,移动操作系统的竞争尤为激烈,其中iOS和Android作为市场上的两大巨头,各自拥有庞大的用户基础和独特的技术特点。本文旨在通过对比分析iOS与Android的核心差异,探讨各自的优势与局限,并提出针对性的优化策略,以期为用户提供更优质的使用体验和为开发者提供有价值的参考。

推荐镜像

更多