【Android 逆向】Android 进程注入工具开发 ( 注入代码分析 | 调试进程 ATTACH 附着目标进程 | 读取目标函数寄存器值并存档 )

简介: 【Android 逆向】Android 进程注入工具开发 ( 注入代码分析 | 调试进程 ATTACH 附着目标进程 | 读取目标函数寄存器值并存档 )

文章目录

一、调试进程 ATTACH 附着目标进程

二、读取目标函数寄存器值并存档

1、主要操作流程

2、ptrace 函数 PTRACE_GETREGS 读取寄存器值





一、调试进程 ATTACH 附着目标进程


在 【Android 逆向】Android 进程注入工具开发 ( 注入代码分析 | 注入工具的 main 函数分析 ) 博客中 , 在 main 函数中获取了 进程号 PID , 下面开始将 SO 动态库注入该 PID 进程号对应的目标进程 ;


ptrace 函数调用的前提是 , 当前应用必须有 root 权限 , 否则调用会失败 ;


首先 , 调用


ptrace(PTRACE_ATTACH, pid, NULL, 0)


函数附着目标进程 , 获取目标进程的控制权 , 传入 PTRACE_ATTACH 参数 ;


具体的 ptrace 函数族的参数 , 参考 【Android 逆向】ptrace 函数 ( ptrace 函数族 | 进程附着 | 进程脱离 | 进程数据读写权限 | 进程对应的主线程寄存器读写 | 单步调试 |ptrace 函数族状态转换 ) 博客 ;


之后 , 需要 阻塞等待 被调试 的 目标进程返回 , 如果目标进程状态变为 WUNTRACED 被调试状态 , 就可以执行下一步的操作 ;


int status = 0;
  /* 等待关联进程结果返回 , 目标进程状态变为 WUNTRACED */
  waitpid(pid, &status, WUNTRACED);



附着目标进程完整代码 :


/* 附着目标进程 */
int ptrace_attach(pid_t pid)
{
  /* attach 关联 要调试的 目标进程 */
  if (ptrace(PTRACE_ATTACH, pid, NULL, 0) < 0) {
  perror("ptrace_attach");
  return -1;
  }
  int status = 0;
  /* 等待关联进程结果返回 , 目标进程状态变为 WUNTRACED */
  waitpid(pid, &status, WUNTRACED);
  return 0;
}





二、读取目标函数寄存器值并存档



1、主要操作流程


声明两个结构体 , 分别用于寄存器值操作 和 存档 , 存档的结构体一定不要写入数据 , 之后恢复寄存器值时需要用到 ;


/* regs 结构体 用于存储寄存器值
    original_regs 结构体 用于存储寄存器值存档 */
  struct pt_regs regs, original_regs;


之后 , 调用 ptrace_getregs 函数 , 读取目标进程的寄存器值 ;


/* 获取寄存器值 */
  if (ptrace_getregs(target_pid, &regs) == -1)
  goto exit;


最后 , 将寄存器的值存档 ,


/* save original registers 寄存器值存档 */
  memcpy(&original_regs, &regs, sizeof(regs));


寄存器读取存档代码示例 :


/* regs 结构体 用于存储寄存器值
    original_regs 结构体 用于存储寄存器值存档 */
  struct pt_regs regs, original_regs;
  /* 获取寄存器值 */
  if (ptrace_getregs(target_pid, &regs) == -1)
  goto exit;
  /* save original registers 寄存器值存档 */
  memcpy(&original_regs, &regs, sizeof(regs));



2、ptrace 函数 PTRACE_GETREGS 读取寄存器值


在 ptrace_getregs 函数中 , 调用


ptrace(PTRACE_GETREGS, pid, NULL, regs)


方法 , 获取目标进程的寄存器数据 , 传入 PTRACE_GETREGS 参数 ;


具体的 ptrace 函数族的参数 , 参考 【Android 逆向】ptrace 函数 ( ptrace 函数族 | 进程附着 | 进程脱离 | 进程数据读写权限 | 进程对应的主线程寄存器读写 | 单步调试 |ptrace 函数族状态转换 ) 博客 ;


/* 获取寄存器值 */
int ptrace_getregs(pid_t pid, struct pt_regs* regs)
{
  if (ptrace(PTRACE_GETREGS, pid, NULL, regs) < 0) {
  perror("ptrace_getregs: Can not get register values");
  return -1;
  }
  return 0;
}


目录
相关文章
|
1月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
109 13
|
4月前
|
Linux C语言
C语言 多进程编程(三)信号处理方式和自定义处理函数
本文详细介绍了Linux系统中进程间通信的关键机制——信号。首先解释了信号作为一种异步通知机制的特点及其主要来源,接着列举了常见的信号类型及其定义。文章进一步探讨了信号的处理流程和Linux中处理信号的方式,包括忽略信号、捕捉信号以及执行默认操作。此外,通过具体示例演示了如何创建子进程并通过信号进行控制。最后,讲解了如何通过`signal`函数自定义信号处理函数,并提供了完整的示例代码,展示了父子进程之间通过信号进行通信的过程。
|
4月前
|
编译器
【收藏】内核级利用通用Hook函数方法检测进程
【收藏】内核级利用通用Hook函数方法检测进程
|
5月前
|
Java 调度 Android开发
Android经典实战之Kotlin的delay函数和Java中的Thread.sleep有什么不同?
本文介绍了 Kotlin 中的 `delay` 函数与 Java 中 `Thread.sleep` 方法的区别。两者均可暂停代码执行,但 `delay` 适用于协程,非阻塞且高效;`Thread.sleep` 则阻塞当前线程。理解这些差异有助于提高程序效率与可读性。
95 1
|
5月前
|
Linux API
Linux源码阅读笔记07-进程管理4大常用API函数
Linux源码阅读笔记07-进程管理4大常用API函数
|
6月前
|
安全 Android开发 Kotlin
Android经典面试题之Kotlin中常见作用域函数
**Kotlin作用域函数概览**: `let`, `run`, `with`, `apply`, `also`. `let`安全调用并返回结果; `run`在上下文中执行代码并返回结果; `with`执行代码块,返回结果; `apply`配置对象后返回自身; `also`附加操作后返回自身
67 8
|
7月前
|
监控 Linux 应用服务中间件
探索Linux中的`ps`命令:进程监控与分析的利器
探索Linux中的`ps`命令:进程监控与分析的利器
154 13
|
6月前
|
运维 关系型数据库 MySQL
掌握taskset:优化你的Linux进程,提升系统性能
在多核处理器成为现代计算标准的今天,运维人员和性能调优人员面临着如何有效利用这些处理能力的挑战。优化进程运行的位置不仅可以提高性能,还能更好地管理和分配系统资源。 其中,taskset命令是一个强大的工具,它允许管理员将进程绑定到特定的CPU核心,减少上下文切换的开销,从而提升整体效率。
掌握taskset:优化你的Linux进程,提升系统性能
|
6月前
|
弹性计算 Linux 区块链
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
212 4
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
|
5月前
|
算法 Linux 调度
探索进程调度:Linux内核中的完全公平调度器
【8月更文挑战第2天】在操作系统的心脏——内核中,进程调度算法扮演着至关重要的角色。本文将深入探讨Linux内核中的完全公平调度器(Completely Fair Scheduler, CFS),一个旨在提供公平时间分配给所有进程的调度器。我们将通过代码示例,理解CFS如何管理运行队列、选择下一个运行进程以及如何对实时负载进行响应。文章将揭示CFS的设计哲学,并展示其如何在现代多任务计算环境中实现高效的资源分配。

热门文章

最新文章

  • 1
    Linux:进程间通信(共享内存详细讲解以及小项目使用和相关指令、消息队列、信号量)
  • 2
    2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
  • 3
    从零开始掌握进程间通信:管道、信号、消息队列、共享内存大揭秘
  • 4
    [JavaEE]———进程、进程的数据结构、进程的调度
  • 5
    如何区分进程、线程和协程?看这篇就够了!
  • 6
    硬核揭秘:线程与进程的底层原理,面试高分必备!
  • 7
    app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
  • 8
    【03】优雅草央千澈详解关于APP签名以及分发-上架完整流程-第三篇安卓APP上架华为商店后面的步骤-华为应用商店相对比较麻烦一些-华为商店安卓上架
  • 9
    【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
  • 10
    【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
  • 相关实验场景

    更多