当前位置: 首页 > news >正文

Android 插件化

参考Android插件化学习之路(一)之动态加载综述_android 动态加载资源-CSDN博客

有三种方式实现插件化,这三种方式的前提都需要在宿主App中创建代理Activity

1.反射

        在宿主Activity的生命周期方法中通过反射调用插件Activiy的生命周期方法

2.hook AMS

        安卓插件化中的 Hook AMS 技术是通过拦截并篡改 ActivityManagerService(AMS)对组件生命周期的管理逻辑,从而实现动态加载未注册插件组件的核心手段。其核心原理在于利用反射机制和动态代理技术,在系统与应用层的交互过程中“偷梁换柱”:当应用层通过 startActivity 请求启动未在 AndroidManifest.xml 中注册的插件 Activity 时,系统会通过 Binder 调用向 AMS 发起请求,此时通过 Hook 机制拦截 IActivityTaskManager 接口的 startActivity 方法,将原始 Intent 中的目标组件替换为宿主中已预注册的代理占位组件(如 ProxyActivity),以此绕过 AMS 对插件 Activity 的合法性校验;待 AMS 完成并通知应用进程启动目标组件时,再通过 Hook ActivityThread 内部的 Handler 对象,拦截 LAUNCH_ACTIVITY 消息并恢复原始插件组件调度信息,最终由系统完成插件 Activity 的实例化与生命周期调用。这一过程涉及两次关键 Hook:首次在客户端发起请求时伪装身份,二次在服务端回调时还原真实意图,例如在 Android 10 的实现中需修改 IActivityTaskManager 的 AIDL 调用链,并动态替换 ApplicationThread 的调度逻辑。然而,此类技术需面对系统版本差异(如 Android 8 后对非公开 API 的限制)、Binder 接口变更(如 IActivityManager 合并为 IActivityTaskManager)、厂商定制系统兼容性问题,以及因频繁反射操作引发的性能损耗和崩溃风险。腾讯 QZone、Tinker 等插件化框架正是基于此类 Hook 策略,结合 DexClassLoader 动态加载机制与资源隔离方案,实现了免安装运行插件、热修复及模块化扩展功能,但同时也对系统稳定性维护提出了更高要求。

精简

在startActivity方法中,将插件Activity替换成代理Activity,这样可以绕过AMS 对Activity 的合法性校验。当 AMS 通知应用进程启动代理Activity时,拦截 LAUNCH_ACTIVITY 消息并将代理Activity替换为插件Activity

3.hook Instrumentation

        安卓插件化中的 Hook Instrumentation 技术是一种通过拦截并篡改系统对组件生命周期管理的核心手段,其本质是利用反射机制篡改 ActivityThread 中的 mInstrumentation 实例,从而控制组件的启动与创建流程。具体实现中,开发者会先通过反射获取当前进程的 ActivityThread 对象,进而提取系统默认的 Instrumentation 实例,并创建一个自定义的代理类(如 FixInstrumentation)继承并重写其关键方法(如 execStartActivity 和 newActivity)。在 execStartActivity 中,开发者会检测待启动的 Intent 是否指向未注册的插件 Activity(如 com.example.PluginActivity),若匹配则将其替换为宿主中已注册的代理占位组件(如 ProxyActivity),同时将原始目标组件信息暂存于 Intent 的附加数据中;而在 newActivity 方法中,则通过恢复原始组件类名并调用父类方法完成插件 Activity 的真实实例化。这一过程绕过了 Android 系统对未在 AndroidManifest.xml 中注册组件的校验逻辑,实现了动态加载插件组件的功能。然而,该技术需面对不同安卓版本中类结构差异、系统对非公开 API 的限制(如 Android 9 后的私有接口限制)以及厂商定制系统导致的兼容性问题,同时也需警惕因反射操作引发的性能损耗和潜在崩溃风险。此类 Hook 技术广泛应用于插件化框架(如 DroidPlugin、VirtualApk)中,为模块化开发、热修复及动态功能扩展提供了底层支持。

精简

通过反射替换 ActivityThread 中的 Instrumentation 实例,Instrumentation用来管理Activity的生命周期和创建Activity,利用自定义代理类拦截组件启动流程,在 execStartActivity 中将插件 Activity 替换为代理Activity以绕过 AMS 校验,并在 newActivity 方法中将代理Activity替换为插件Activity

相关文章:

  • More SQL(Focus Subqueries、Join)
  • python完成批量复制Excel文件并根据另一个Excel文件中的名称重命名
  • 高效合并 Excel 表格实用工具
  • c++第三天(对象与构造函数)
  • MySQL 数据迁移Postgresql(openGuass) 之 pg_chameleon
  • 【Python办公】Excel简易透视办公小工具
  • EasyExcel使用导出模版后设置 CellStyle失效问题解决
  • C++ 异步编程与网络编程:工具、协议的层次与协同
  • 金砖国家人工智能高级别论坛在巴西召开,华院计算应邀出席并发表主题演讲
  • 多相电机驱动控制学习(2)——基于双dq的双三相PMSM学习(考虑互感/交叉耦合)
  • 网络协议入门:TCP/IP五层模型如何实现全球数据传输?
  • 学习STC51单片机18(芯片为STC89C52RCRC)
  • 微信小程序页面嵌套web-view点击系统导航返回时进行弹窗处理
  • WPF的基础控件:布局控件(StackPanel DockPanel)
  • RabbitMQ仲裁队列高可用架构解析
  • 720全景展示:VR全景的技术原理及应用
  • 深入理解设计模式之中介者模式
  • AudioTrack的理解
  • 用豆包写单元测试
  • 服务器定时任务查看和编辑
  • 高职图书馆网站建设大赛/网站搭建谷歌seo
  • b2b电子商务平台官网/百度推广账户优化
  • 360产品展示网站/百度关键词优化多少钱一年
  • 网站建设专业导航网站/百度关键字搜索排名
  • 重庆网站推广优化/中南建设集团有限公司
  • 网站谁做的比较好看的/seo做得比较好的公司