Bootstrap

Android NDK

Android NDK环境

D:\Android SDK\ndk\25.2.9519653 

使用clang而不用gcc

D:\Android SDK\ndk\25.1.8937393\toolchains\llvm\prebuilt\windows-x86_64\bin\clang --version 

查看是否安装成功clang

ptrace

在 C 语言中,ptrace 已经被 Linux 内核实现,你可以在 sys/ptrace.h 头文件中找到它。

ptrace 常用功能

功能调用方式作用
调试自身ptrace(PTRACE_TRACEME, 0, 0, 0)检测调试器(反调试)
附加到进程ptrace(PTRACE_ATTACH, pid, 0, 0)控制另一个进程(外挂/Hook)
读取进程内存ptrace(PTRACE_PEEKDATA, pid, addr, 0)读目标进程的内存
写入进程内存ptrace(PTRACE_POKEDATA, pid, addr, data)修改目标进程的数据(外挂/破解)
修改寄存器ptrace(PTRACE_SETREGS, pid, 0, &regs)修改 CPU 寄存器(绕过检测)
恢复进程执行ptrace(PTRACE_CONT, pid, 0, 0)

继续运行被调试的进程

  • 用 Frida 绕过 ptrace
  • 用 IDA Patch 二进制,让 ptrace 失效
  • LD_PRELOAD Hook ptrace()

层级DEX 层(Java)Native 层(so)
代码语言Java / SmaliC / C++
运行环境ART / Dalvik VM直接运行在 CPU 上
存储文件classes.dexlibnative-lib.so
修改方法jadxFridasmaliIDAFridaInline Hook

层级代码类型运行环境作用
1️⃣ Java 层.java → classes.dexART/Dalvik VM应用逻辑
2️⃣ Smali 层.smaliART/Dalvik VMJava 层的低级字节码
3️⃣ Native 层JNI 调用 C/C++通过 JNI 调用 so桥接 Java 和 C/C++
4️⃣ SO 层.so(C/C++ 代码)直接运行在 CPU底层优化(加密、计算)

📌 CMake 在 Android NDK 中的作用

在 Android 开发中:

  1. CMake 编译 C/C++ 代码,生成 libnative-lib.so
  2. Java 通过 JNI 调用 so
  3. CMake 让 so 库支持不同的 CPU 架构(arm64、x86 等)

;