当前位置: 首页 > article >正文

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


http://www.kler.cn/a/525226.html

相关文章:

  • ES2021+新特性、常用函数
  • C++中的类与对象(中)
  • 【性能优化专题系列】利用CompletableFuture优化多接口调用场景下的性能
  • 批量卸载fnm中已经安装的所有版本
  • 【HarmonyOS之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(三)
  • PHP 7 新特性
  • “AI视频智能分析系统:让每一帧视频都充满智慧
  • 寻找旋转数组中的最小元素:C语言实现与分析
  • SSM开发(七) MyBatis解决实体类(model)的字段名和数据库表的列名不一致方法总结(四种方法)
  • Baklib引领企业内容中台建设的新思路与应用案例
  • 更新被联想限制更新的intel集成显卡UHD 630驱动,想让老显卡也支持到4K显示器
  • pandas(一)创建文件、写入数据
  • Brave132 编译指南 Windows 篇:获取源码(六)
  • Git进阶之旅:Git 配置信息 Config
  • Mybatis是如何进行分页的?
  • Vue.js 什么是 Composition API?
  • MySQL知识点总结(十一)
  • 【数据结构】动态内存管理函数
  • 小程序-视图与逻辑
  • Ansible自动化运维实战--fetch、cron和group模块(5/8)
  • 微调Qwen2:7B模型,加入未知信息语料
  • WPF基础03——InitializeComponent()函数解释
  • Microsoft Power BI:融合 AI 的文本分析
  • Yii框架中的扩展:如何使用外部库
  • 《从因果关系的角度学习失真不变表示以用于图像恢复》学习笔记
  • 以创新芯片技术助力科技发展