首页 > 其他分享 >又一开源项目爆火于GitHub,Android高级插件化强化实战

又一开源项目爆火于GitHub,Android高级插件化强化实战

时间:2023-06-19 11:01:25浏览次数:57  
标签:插件 GitHub 爆火于 Apk 应用 组件 Android 加载


一、插件化起源

插件化技术最初源于免安装运行 Apk的想法,这个免安装的 Apk 就可以理解为插件,而支持插件的 app 我们一般叫 宿主。

想必大家都知道,在 Android 系统中,应用是以 Apk 的形式存在的,应用都需要安装才能使用。但实际上 Android 系统安装应用的方式相当简单,其实就是把应用 Apk 拷贝到系统不同的目录下、然后把 so 解压出来而已。

常见的应用安装目录有:

  • /system/app:系统应用
  • /system/priv-app:系统应用
  • /data/app:用户应用

那可能大家会想问,既然安装这个过程如此简单,Android 是怎么运行应用中的代码的呢,我们先看 Apk 的构成,一个常见的 Apk 会包含如下几个部分:

  • classes.dexJava 代码字节码
  • res:资源文件
  • libso 文件
  • assets:静态资产文件
  • AndroidManifest.xml:清单文件

其实 Android 系统在打开应用之后,也只是开辟进程,然后使用 ClassLoader 加载 classes.dex 至进程中,执行对应的组件而已。

那大家可能会想一个问题,既然 Android 本身也是使用类似反射的形式加载代码执行,凭什么我们不能执行一个 Apk 中的代码呢?

二、插件化优点

插件化让 Apk 中的代码(主要是指 Android 组件)能够免安装运行,这样能够带来很多收益:

  • 减少安装Apk的体积、按需下载模块
  • 动态更新插件
  • 宿主和插件分开编译,提升开发效率
  • 解决方法数超过65535的问题

想象一下,你的应用拥有 Native 应用一般极高的性能,又能获取诸如 Web 应用一样的收益。

嗯,理想很美好不是嘛?

三、与组件化的区别

  • 组件化:是将一个App分成多个模块,每个模块都是一个组件(module),开发过程中可以让这些组件相互依赖或独立编译、调试部分组件,但是这些组件最终会合并成一个完整的Apk去发布到应用市场。
  • 插件化:是将整个App拆分成很多模块,每个模块都是一个Apk(组件化的每个模块是一个lib),最终打包的时候将宿主Apk和插件Apk分开打包,只需发布宿主Apk到应用市场,插件Apk通过动态按需下发到宿主Apk。

四、插件化的技术难点

想让插件的Apk真正运行起来,首先要先能找到插件Apk的存放位置,然后我们要能解析加载Apk里面的代码。

但是光能执行Java代码是没有意义的,在Android系统中有四大组件是需要在系统中注册的,具体来说是在 Android 系统的 ActivityManagerService (AMS)PackageManagerService (PMS) 中注册的,而四大组件的解析和启动都需要依赖 AMSPMS,如何欺骗系统,让他承认一个未安装的 Apk 中的组件,如何让宿主动态加载执行插件Apk中 Android 组件(即 ActivityServiceBroadcastReceiverContentProviderFragment)等是插件化最大的难点。

另外,应用资源引用(特指 R 中引用的资源,如 layoutvalues 等)也是一大问题,想象一下你在宿主进程中使用反射加载了一个插件 Apk,代码中的 R 对应的 id 却无法引用到正确的资源,会产生什么后果。

总结一下,其实做到插件化的要点就这几个:

  • 如何加载并执行插件 Apk 中的代码(ClassLoader Injection
  • 让系统能调用插件 Apk 中的组件(Runtime Container
  • 正确识别插件 Apk 中的资源(Resource Injection

插件化是一门很有意思的学问,网上已经有很多“入门知识”和“实现原理”之类的文章,但是关于插件化的实战却没有一个系统、全面的分享,下面我要分享的是最近小编有幸在腾讯高工手里扒到这份“插件化实战学习手册",这位大佬主导开发过多个采用插件化架构的APP项目。手册中收录了各互联网大厂热门的插件化项目实战,从新手到架构师,这份学习手册足以。

第一章、插件化技术的前世今生

  • 插件化提要
  • 插件化发展历史

第二章 插件化原理

  • 类加载
  • 双亲委托机制
  • 资源加载
  • 四大组件支持
  • Proxy Activity代理
  • hook方式

又一开源项目爆火于GitHub,Android高级插件化强化实战_android

第三章 Android插件化初探

  • 从零开始实现一个插件化框架
  • Activity的启动流程
  • 寻找Hook点
  • 撸码阶段
  • 代理对象
  • 偷天换日,替换原来的Intent
  • ActivityThread
  • 将代理的intent替换回来

又一开源项目爆火于GitHub,Android高级插件化强化实战_android_02

第四章 架构演化(大厂篇)

  • 360插件开发之DroidPlugin
    插件开发之360 DroidPlugin源码分析
    插件开发之360 DroidPlugin源码分析之Hook机制
    Hook机制的包结构关系
    Hook机制类图关系
    Hook机制的时序图关系
    Manifest权限申请
    基类Hook做了什么?

又一开源项目爆火于GitHub,Android高级插件化强化实战_插件化_03

  • 滴滴VirtualApk实战
    配置
    应用
    原理
    总结
    问题

又一开源项目爆火于GitHub,Android高级插件化强化实战_加载_04

  • 基于VirtualAPK Android重构之插件化
    Plug-in Hello World
    插件化框架的选择
    插件化原理
    引入插件化之痛

又一开源项目爆火于GitHub,Android高级插件化强化实战_android_05

  • 爱奇艺插件化原理分析之 Neptune框架
    插件化基础知识点
    类加载
    插件化中资源使用限制
    Apk打包流程
    四大组件的插件化
    插件Activity任务栈
    处理插件中的广播
    处理插件中的Service

又一开源项目爆火于GitHub,Android高级插件化强化实战_插件化_06

  • 腾讯插件化框架 Shadow项目解析
    sample示例代码AndroidManifest.xml分析
    Activity 实现
    替换插件 Activity 的父类
    Service 实现
    BroadcastReceiver 实现
    ContentProvider 实现
    框架自身动态化

标签:插件,GitHub,爆火于,Apk,应用,组件,Android,加载
From: https://blog.51cto.com/u_16163452/6511753

相关文章

  • vscode配置yapf格式化插件
    引言yapf比autopep8更加灵活和强大,可以考虑入手配置步骤安装yapf:pipinstallyapfvscode配置setting.json"python.formatting.provider":"yapf","python.formatting.yapfArgs":["--style={based_on_style=pep8,arithmetic_precede......
  • vue中前端实现pdf预览(含vue-pdf插件用法)
    场景:前端需要根据后端返回的线上pdf的地址,实现pdf的预览功能。情况一:后端返回的pdf地址,粘贴到浏览器的url框中,是可以在浏览器中直接进行预览的。方法(1)可以直接使用window.open('获取到的pdf地址')重新打开一个浏览器页签,通过浏览器页签直接实现预览功能(预览页面的样式,根据浏览器的不......
  • 你的专属音乐生成器「GitHub 热点速览」
    如果你制作视频,一定会碰到配乐的问题。虽然网上找的一些免费配乐能勉强满足需求,但是如果有个专属的配乐生成器,根据你的视频画面生成对应配乐是不是不错呢?audiocraft也许能帮助你,把相关画面用文本描述一下,它就能生成相对应的音乐。当然,本周除了文本生成音乐的audiocraft之外,还......
  • selenium 使用本地浏览器插件
    <table><tr><tdbgcolor=orange>本文所有教程及源码、软件仅为技术研究。不涉及计算机信息系统功能的删除、修改、增加、干扰,更不会影响计算机信息系统的正常运行。不得将代码用于非法用途,如侵立删!</td></tr></table>selenium使用本地浏览器插件环境win10Python3.9seleniu......
  • dremio 24.1 Nessie 支持插件
    以前也简单说过24.1支持基于Nessie进行查询了,相关代码名称比较怪异(此代码开源了),名称为dataplane参考代码信息 说明因为dremio云版本支持基于Nessie的元数据管理,此功能代码还是值得学习参考的,整体开发上也是一个标准的存储扩展参考资料https://docs.dremio.com/software......
  • git push 到 github 报错:10054
    解决方式:终端也要设置代理exporthttps_proxy=http://127.0.0.1:33210http_proxy=http://127.0.0.1:33210all_proxy=socks5://127.0.0.1:33211......
  • wordpress插件:WP-UTF8-Excerpt使列表页只显示摘要(wordpress 6.2)
    一,安装WP-UTF8-Excerpt插件这个插件有点老,大家有更新及时的插件欢迎留言交流安装完成后,点击启用按钮二,查看效果说明:刘宏缔的架构森林—专注it技术的博客,网站:https://blog.imgtouch.com原文: https://blog.imgtouch.com/index.php/2023/06/18/wordpress-cha-jian-wputf......
  • 配置github pages教程
    参考文档github-stylethemegithubactions教程基础配置mkdirmyblog&&[email protected]:MeiK2333/github-style.gitthemes/github-stylevim.gitignoregitadd.gitpush-uoriginmaster更新主题cdthemes/......
  • AI自动写书神器,3个ChatGPT插件让你轻松赚钱!
    AI自动写书神器,3个ChatGPT插件让你轻松赚钱!你是否想过,有一天,你可以只给一个主题,让AI自动搜集资料并写出一本电子书?你是否想过,有一天,你可以不用动笔,就能成为畅销书作者?你是否想过,有一天,你可以利用AI的智慧和创造力,轻松赚取被动收入?如果你的答案是肯定的,那么恭喜你,你的梦想已经成为......
  • 使用油猴替换github下载地址
    举例:通过油猴下载https://www.cocoacontrols.com/的GitHub代码//==UserScript==//@namecocoacontrols.com下载代码//@namespacehttp://tampermonkey.net///@version0.1//@descriptiontrytotakeovertheworld!//@authorCoderWGB/......