码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【Android 逆向】ART 函数抽取加壳 ③ ( 禁用 dex2oat 操作 HOOK 点介绍 | 集成 InLineHook )


    文章目录

    • 一、禁用 dex2oat 操作 HOOK 点介绍
    • 二、集成 InLineHook


    在

    • 【Android 逆向】ART 函数抽取加壳 ① ( ART 下的函数抽取恢复时机 | 禁用 dex2oat 机制源码分析 )
    • 【Android 逆向】ART 函数抽取加壳 ② ( 禁用 dex2oat 简介 | TurboDex 中禁用 dex2oat 参考示例 )

    两篇博客中 , 简单介绍了 禁用 dex2oat 机制 的原理 , 下面开始 实现 dex2oat 禁用功能 ;





    一、禁用 dex2oat 操作 HOOK 点介绍



    dex2oat 机制 的实现流程中 , 其中需要调用 exec_utils.cc 源码中的 ExecAndReturnCode 函数 , 在 ExecAndReturnCode 函数 中调用了 execve 函数 , 源码片段如下 :

    int ExecAndReturnCode(std::vector<std::string>& arg_vector, std::string* error_msg) {
        if (envp == nullptr) {
          execv(program, &args[0]);
        } else {
          execve(program, &args[0], envp);
        }
        return -1;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

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





    二、集成 InLineHook



    在上个章节介绍的 exec_utils.cc 源码 编译后的二进制代码被封装到了 libc 库 中 ;


    禁用 dex2oat 机制 , 需要 HOOK libc 库中的 execve 函数 , HOOK Java 代码 , 使用静态代理 或 动态代理 模式即可 , HOOK C 语言中的代码需要使用 InLineHook , 这里先集成 InLineHook ;

    将 相关源码拷贝到 app\src\main\cpp\ 目录下 , 主要源码结构如下 :

    │  CMakeLists.txt
    │  native-lib.cpp
    │
    └─hook
        │  inlineHook.c
        │  relocate.c
        │  relocate.h
        │  TKHooklib.h
        │
        ├─dlfcn
        │      dlfcn_compat.c
        │      dlfcn_compat.h
        │      dlfcn_nougat.c
        │      dlfcn_nougat.h
        │
        └─include
                inlineHook.h
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    在 CMakeLists.txt 构建脚本中 , 进行如下配置 :

    add_library( 
    		# 设置函数库名称
            native-lib
            # 设置函数库类型 , 动态库
            SHARED
            # 指定 InLineHook 涉及到的 .c 源码
            hook/relocate.c
            hook/inlineHook.c
            hook/dlfcn/dlfcn_nougat.c
            hook/dlfcn/dlfcn_compat.c
            # 核心功能源码
            native-lib.cpp)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    集成了 InLineHook 库之后 , 在 native-lib.cpp 中导入 inlineHook.h 头文件 , 就可以调用如下 内联钩子 InLineHook 函数 , 如 :

    enum ele7en_status registerInlineHook(uint32_t target_addr, uint32_t new_addr, uint32_t **proto_addr);
    enum ele7en_status inlineUnHook(uint32_t target_addr);
    void inlineUnHookAll();
    enum ele7en_status inlineHook(uint32_t target_addr);
    void inlineHookAll();
    
    • 1
    • 2
    • 3
    • 4
    • 5
  • 相关阅读:
    【Proteus仿真】【STM32单片机】防火防盗GSM智能家居设计
    JAVA集合2-Vector
    Halo 开源项目学习(二):实体类与数据表
    防火墙命令补充和dmz_远程管理
    Docker常用命令
    基于SIFT图像特征识别的匹配方法比较与实现
    算法通关村第十七关:黄金挑战-跳跃游戏问题
    java面向对象的三大特性之封装和继承(配视频讲解)
    Dragonfly 基于 P2P 的文件和镜像分发系统
    【华为OD机试真题 python】数组组成的最小数字 【2022 Q4 | 100分】
  • 原文地址:https://blog.csdn.net/han1202012/article/details/127434894
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号