Launcher 如何通过startActivity 传送一个 intent 到 zygote 如何 接收到它并且 fork出该app的进程的?

安装框架的时候会现有各种检查,比如当前系统版本等

下载对应的框架安装文件

安装文件是个zip文件

下载完成后会检查zip文件,通过下面的方法检查

InstallZipUtil. checkZip()

  1. META-INF/com/google/android/update-binary 是否存在
  2. META-INF/com/google/android/flash-script.sh 是否存在

安装方式有种 1. 直接刷入  2.通过recover自动刷入

安装框架最关键的代码在Falshable 的2个子类的 falsh() 方法种

1.直接刷入

FlashDirectly

1.把zip包种的 META-INF/com/google/android/update-binary

复制到 App. getCacheDir() / update-binary

然后用 supperuser 以 root 权限 执行

。。。

int result = rootUtil.execute(getShellPath(updateBinaryFile) + " 2 1 " + getShellPath(mZipPath), callback);

。。。

直接刷入:用root权限执行了zip里的update-binary 可执行文件

2.recover自动刷入

FlashRecoveryAuto

1.

在 /cache/recovery

目录下(没有就用root权限创建)

2.

复制zip到 /cache/recovery/

3.

写入刷入命令到

/cache/recovery/command

文件中

cmd = "echo --update_package=/cache/recovery/" + zipName + " > /cache/recovery/command";

所以重点又到了update-binary做了什么

这个文件从make 系统的ota升级包中复制同名文件

两种方式最终结果都是安装了所需的文件

分析 sh

检查 system/xposed.prop

Mounting /system and /vendor read-write

从 system/build.prop 确定system/ arch 如 X86或arm 等属性,然后做一些如版本号、平台架构匹配之类的校验

校验通过后,会释放一些文件到指定位置

/system/xposed.prop

/system/framework/XposedBridge.jar

(在zip包中的几乎都要释放到对应位置)

然后配置文件权限和selinux

主要是修改后的虚拟机(art dvm) /system/lib/libart.so , system/lib/libart-compiler.so 等等一系列so文件

还有入口app_process32

以及自身框架 system/framework/XposedBridge.jar

一段释放文件的源码:

install_nobackup /system/xposed.prop                      0    0 0644

install_nobackup /system/framework/XposedBridge.jar       0    0 0644

install_and_link  /system/bin/app_process32               0 2000 0755 u:object_r:zygote_exec:s0

install_overwrite /system/bin/dex2oat                     0 2000 0755 u:object_r:dex2oat_exec:s0

install_overwrite /system/bin/dexdiag                     0 2000 0755

install_overwrite /system/bin/dexlist                     0 2000 0755

install_overwrite /system/bin/dexoptanalyzer              0 2000 0755 u:object_r:dexoptanalyzer_exec:s0

install_overwrite /system/bin/oatdump                     0 2000 0755

install_overwrite /system/bin/patchoat                    0 2000 0755 u:object_r:dex2oat_exec:s0

install_overwrite /system/bin/profman                     0 2000 0755 u:object_r:profman_exec:s0

install_overwrite /system/lib/libart.so                   0    0 0644

install_overwrite /system/lib/libart-compiler.so          0    0 0644

install_overwrite /system/lib/libart-dexlayout.so         0    0 0644

install_overwrite /system/lib/libart-disassembler.so      0    0 0644

install_overwrite /system/lib/libsigchain.so              0    0 0644

install_overwrite /system/lib/libopenjdkjvm.so            0    0 0644

install_overwrite /system/lib/libopenjdkjvmti.so          0    0 0644

install_nobackup  /system/lib/libxposed_art.so            0    0 0644

if [ $IS64BIT ]; then

install_and_link  /system/bin/app_process64             0 2000 0755 u:object_r:zygote_exec:s0

install_overwrite /system/lib64/libart.so               0    0 0644

install_overwrite /system/lib64/libart-compiler.so      0    0 0644

install_overwrite /system/lib64/libart-dexlayout.so     0    0 0644

install_overwrite /system/lib64/libart-disassembler.so  0    0 0644

install_overwrite /system/lib64/libsigchain.so          0    0 0644

install_overwrite /system/lib64/libopenjdkjvm.so        0    0 0644

install_overwrite /system/lib64/libopenjdkjvmti.so      0    0 0644

install_nobackup  /system/lib64/libxposed_art.so        0    0 0644

fi

综合来说,这个安装脚本主要就是

根据当前平台特性,释放对应的文件覆盖到/system下原来的诸如虚拟机的相关文件

XposedInstaller 是如何安装的的更多相关文章

  1. - 反编译 AndroidKiller 逆向 实践案例 MD

    目录 目录 反编译 AndroidKiller 逆向 实践案例 MD AndroidKiller 简介 插件升级 基本使用 实践案例 修改清单文件 打印 debug 级别的日志 方式一:直接代理 Lo ...

  2. mumu模拟器安装xposed--如何在android模拟器上进行root

    问题描述 安装xposed表示failed to access root权限,新版的mumu模拟器没有了root选项,需要自己root. 1.先关掉应用兼容性,然后重启 电脑一般都是x86的,mumu ...

  3. 小米5安装Xposed框架——需要解锁刷机

    Xposed官网 https://forum.xda-developers.com/xposed 官方模块厂库 https://repo.xposed.info/ 中文站点 https://xpose ...

  4. docker——容器安装tomcat

    写在前面: 继续docker的学习,学习了docker的基本常用命令之后,我在docker上安装jdk,tomcat两个基本的java web工具,这里对操作流程记录一下. 软件准备: 1.jdk-7 ...

  5. 网络原因导致 npm 软件包 node-sass / gulp-sass 安装失败的处理办法

    如果你正在构建一个基于 gulp 的前端自动化开发环境,那么极有可能会用到 gulp-sass ,由于网络原因你可能会安装失败,因为安装过程中部分细节会到亚马逊云服务器上获取文件.本文主要讨论在不变更 ...

  6. Sublime Text3安装JsHint

    介绍 Sublime Text3使用jshint依赖Nodejs,SublimeLinter和Sublimelinter-jshint. NodeJs的安装省略. 安装SublimeLinter Su ...

  7. Fabio 安装和简单使用

    Fabio(Go 语言):https://github.com/eBay/fabio Fabio 是一个快速.现代.zero-conf 负载均衡 HTTP(S) 路由器,用于部署 Consul 管理的 ...

  8. gentoo 安装

    加载完光驱后 1进行ping命令查看网络是否通畅 2设置硬盘的标识为GPT(主要用于64位且启动模式为UEFI,还有一个是MBR,主要用于32位且启动模式为bois) parted -a optima ...

  9. Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级

    Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 5.安装Database软件 5. ...

随机推荐

  1. [转载] Java 遍历 Map 的 5 种方式

    目录 1 通过 keySet() 或 values() 方法遍历 2 通过 keySet 的 get(key) 获取值 3 通过 entrySet 遍历 4 通过迭代器 Iterator 遍历 5 通 ...

  2. ENDGAME

    "So if I were to wrap this up tight with a bow or whatever,I guess I'd say my career of OI was ...

  3. 初学Python之爬虫的简单入门

    初学Python之爬虫的简单入门 一.什么是爬虫? 1.简单介绍爬虫   爬虫的全称为网络爬虫,简称爬虫,别名有网络机器人,网络蜘蛛等等. 网络爬虫是一种自动获取网页内容的程序,为搜索引擎提供了重要的 ...

  4. 关闭Chrome浏览器的广告

    生活没有绝对的对与错:代码就不一样了,错了就编译不过,也正是因为这样,编程的人思维有时也会陷入一种狭隘中,这就是把工作和生活没有分开.Win10 右下角的广告就像程序调试中的"警告" ...

  5. matlab中的colormap

    matlab colormaps 默认颜色图是 parula ,颜色图从左往右数值不断增大. 颜色图名称 色阶 parula jet hsv hot cool spring summer autumn ...

  6. 蓝牙Inquriy 过程详解

    问题 今天遇到了一个问题,就是自己的耳机产品,手机经常搜不到,从日志里面查看,发现原因是平时手机蓝牙发送的是inquiry mode =2 出问题的时候,inquiry mode =1 由于本设备很多 ...

  7. Python必备收藏!博士大佬总结的Pycharm 常用快捷键思维导图

    ​ 搜索 Ctrl + Shift + F7用法高亮显示 Ctrl + Alt + F7显示用法 编辑 ​ Ctrl + Shift + V从最近的缓冲区粘贴 Ctrl + D复制选定的区域或行到后面 ...

  8. SQLserver无法删除数据库 "XXXX",因为该数据库当前正在使用。

    问题描述: 有时候删除库的时候,会显示无法删除数据库,因为该数据库当前正在使用. 解决方法: 方法一: EXEC msdb.dbo.sp_delete_database_backuphistory @ ...

  9. Jenkins操作学习 -- 配置及使用

    一.jenkins基本配置 1.在Jenkins首页,点击Manage Jenkins,然后再点击Manage Plugins插件管理,安装必要的插件.这里我只需要安装Git,因为第一次初始化安装没成 ...

  10. java在hashmap初始化时赋初值

    Java中的HashMap是一种常用的数据结构,一般用来做数据字典或者Hash查找的容器. 一般我们初始化并赋初值是这样做的: HashMap<String, Object> map = ...