文章目录

  • ​​一、Android 热修复系统组成​​
  • ​​二、热修复工作流程​​
  • ​​三、热修复使用到的技术​​
  • ​​四、热修复框架选择注意事项​​






一、Android 热修复系统组成



Android 热修复系统组成 :

  • 手机端 SDK : 在手机中集成一个 SDK , 是 Android 手机端
  • 后端服务器 : 在服务器中 处理 手机端 SDK 的请求数据 , 以及 为管理操作界面进行后端支持 ;
  • 管理操作界面 : Android 开发者通过该界面 , 构建 | 发布 | 管理 | 监控 修复包文件 ;

一般情况下 管理操作界面 和 后端服务器 是一个 Java / .NET / PHP 开发的 Web 应用 ;






二、热修复工作流程



热修复工作流程 :

首先 , 开发者发现 BUG , 使用 Gradle 插件生成 修复包 ;

然后 , 开发者 将修复包上传到 服务器端

最后 , 手机端的 SDK 每次启动都会到 服务器端 检查是否有最新的修复包 , 如果有则下载最新的修复包 , 并在本地配置该修复包 , 每次启动都加载并执行该修复包数据 ;






三、热修复使用到的技术



热修复使用到的技术 :

  • DexClassLoader 动态加载技术 : 主要是使用 自定义 DexClassLoader 类加载器 通过各种 代理 | 反射 | HOOK 等操作 加载外部的字节码数据 ; 热修复 , 插件化 , 换肤框架 都用到该技术 ;
  • 差分打包技术 : 使用 bsdiff.so 动态库
  • 字节码插桩技术 : 使用 ASM , Javassit 技术
  • Android Gradle 插件相关技术 : 开发 自定义 Android Gradle 插件
  • NDK 相关技术 : 需要 编译生成 so 动态库 ;





四、热修复框架选择注意事项



挑选热修复框架时 , 一定要要选择一直保持更新的框架 ;

凡是使用到 插件化 , 热修复 , 加固 等需要 HOOK 操作的框架时 , 必须注意 , HOOK 框架必须适配所有的 Android 版本, Android 源代码每个版本都不一样 , 选择的 HOOK 点也不一样 ;

如果选择 AndFix 热修复框架 , 该框架已经好几年没有更新 , 无法在新版本的手机操作系统中运行 , 一旦运行肯定崩溃 ;

哪怕是去年停止更新 , 支持到了 Android 12 , 今年新出了 Android 13 , 如果使用了该框架 , 则 应用无法在 Android 13 中正常运行;