首页
社区
课程
招聘
[原创][原创]小米学安卓逆向一 - NDK开发(1)
发表于: 2021-5-6 20:05 9149

[原创][原创]小米学安卓逆向一 - NDK开发(1)

2021-5-6 20:05
9149

纯小白一枚,所思皆所写,一点点记录所学。

简单来说,JNI是允许java代码和其他语言进行交互的一种规范,它不是android平台特有,但凡有JVM的地方都支持。

图片描述
那么JNI的出现背景是什么呢?

于是JNI应运而生。

但是需要注意的是,NDK开发的so不再具有跨平台性,基于不同架构的平台,需要编译不同平台支持的二进制接口ABI(Application Binary Interface)

JNI是不限于平台的,只要运行JVM就可以,而NDK是android工具包,开发的so也不支持全平台。

图片描述
图片描述
图片描述
图片描述

build生成apk,我们对apk进行提取(一般是将.apk修改为.zip然后unzip进行解压),打开lib目录,会发现有4个不同架构的目录和so文件,我们把其中arm下的so拖入ida,对照项目函数进行分析。
图片描述

图片描述

即可看到在native-lib.cpp中的函数。

在C++中,为了支持重载,在对程序进行编译和链接的过程中,会进行"命名粉碎"的过程,demo中有增加了extern "C"和未加的函数,在IDA中能看出来,经过命名粉碎的函数名和代码中出现的就完全不一样,加了extern "C"的函数名和代码中一致。

在调用第三方C/C++类库时,应当注意引用时,加入extern "C",不然会出现"命名粉碎"的情况,有可能会导致找不到调用函数名的情况

在CMakeLists.txt中也要记得添加所要引用库的head文件。

代码详情见附件。

链接: https://pan.baidu.com/s/1g6bCbKwBvPsHid0cytUMqQ 密码: m1n3

 
 
 

纯小白一枚,所思皆所写,一点点记录所学。


[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

收藏
免费 2
支持
分享
最新回复 (1)
雪    币: 4474
活跃值: (6348)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
2
第一个图挂了
2021-5-27 20:30
0
游客
登录 | 注册 方可回帖
返回
//