码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【Android 逆向】ART 函数抽取加壳 ② ( 禁用 dex2oat 简介 | TurboDex 中禁用 dex2oat 参考示例 )


    文章目录

    • 一、禁用 dex2oat 简介
    • 二、TurboDex 中禁用 dex2oat 参考示例





    一、禁用 dex2oat 简介



    在上一篇博客 【Android 逆向】ART 函数抽取加壳 ( ART 下的函数抽取恢复时机 | 禁用 dex2oat 机制源码分析 )

    • 分析了 dex2oat 机制 的运行过程 , 即将 Dex 字节码文件 转为 Oat 字节码文件 , 其目的是为了 提高运行效率 ,
    • 在上述第二章节的源码中 , 任意一个位置进行 Hook 操作 , 都可以 打断 dex2oat 的执行过程 , 以达到 关闭字节码优化的目的 ;

    在 ART 虚拟机 下实现 函数抽取 加壳 , 首先要 禁用 dex2oat , 在 【Android 逆向】ART 函数抽取加壳 ( ART 下的函数抽取恢复时机 | 禁用 dex2oat 机制源码分析 ) 二、禁用 dex2oat 机制源码分析 章节 分析 ART 虚拟机下加载 Dex 字节码文件的流程 :

    • DexClassLoader 加载字节码文件
    • InMemoryDexClassLoader 加载字节码文件




    二、TurboDex 中禁用 dex2oat 参考示例



    在 https://github.com/asLody/TurboDex 项目中 , 就禁用了 dex2oat ,

    TurboDex 是一个 快速加载 Dex 的工具 , 在 ART 虚拟机中 , 加载 Dex 后会 自动转为 Oat 格式 , 该过程需要花费很长时间 , 引入 TurboDex 后 , 禁用 dex2oat , 可实现瞬间加载 Dex ;

    在该项目中 , 也是使用了 Hook 【Android 逆向】ART 函数抽取加壳 ( ART 下的函数抽取恢复时机 | 禁用 dex2oat 机制源码分析 ) 博客中介绍的过程 , 实现了 禁用 dex2oat 的功能 ;

    其中文介绍如下 :

    TurboDex: 在Android瞬间加载Dex
    
    众所周知,Android中在Runtime加载一个 未优化的Dex文件 (尤其在 ART 模式)需要花费 很长的时间. 
    当你在App中使用 插件化框架 的时候, 首次加载插件就需要耗费很长的时间.
    
    TurboDex 就是为了解决这一问题而生, 就像是给AndroidVM开启了上帝模式, 
    在引入TurboDex后, 无论你加载了多大的Dex文件,都可以在毫秒级别内完成.
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    参考地址 : https://github.com/asLody/TurboDex/blob/master/CHINESE.md


    在该项目的 TurboDex/project/turbodex/turbodex/src/main/jni/core/FastLoadDex.cpp 代码中 , 有如下代码 :

    void enableFastLoadDex() {
    	if(!hooked) {
    		HOOK(execv);
    		hooked = true;
    	}
    	enable = true;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    说明在 TurboDex 中 , 禁用 dex2oat 是通过 Hook execv 函数实现的 , 与 【Android 逆向】ART 函数抽取加壳 ① ( ART 下的函数抽取恢复时机 | 禁用 dex2oat 机制源码分析 ) 二、禁用 dex2oat 机制源码分析 4、exec_utils.cc#ExecAndReturnCode 源码分析 博客章节分析的源码结论相同 ;

    在 exec_utils.cc#ExecAndReturnCode 源码中 , 有如下代码片段 :

        if (envp == nullptr) {
          execv(program, &args[0]);
        } else {
          execve(program, &args[0], envp);
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    参考源码 : http://aospxref.com/android-8.0.0_r36/xref/art/runtime/exec_utils.cc#ExecAndReturnCode ;

    有的 ART 虚拟机需要 Hook execv 函数 , 有的需要 Hook execve 函数 ;

  • 相关阅读:
    Jmeter组件执行顺序与作用域
    接口测试当中的权限限制测试和状态机测试【杭州多测师_王sir】【杭州多测师】...
    Python实现多子图绘制系统
    CSS篇八
    鼠标维修笔记
    sqlilabs第一关
    FFmpeg入门详解之23:视频转码原理
    GitHub如何删除仓库
    【代码源每日一题】饿饿 饭饭「二分答案」
    组合数求法、卡特兰数
  • 原文地址:https://blog.csdn.net/han1202012/article/details/127416953
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号