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 等)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奶龙牛牛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值