IDA中 初识SO原理

本文介绍了如何使用IDA分析Android的SO库,重点关注SO库的加载位置、加载过程以及Java与C/C++交互的原理。通过示例展示了在IDA中查找导出函数,解析函数签名,并导入头文件以改善翻译质量的过程。
摘要由CSDN通过智能技术生成

记住一点:
IDA 不是全能的 翻译C代码时 并不能精准的翻译出来所有代码
最关键的还是要考 汇编代码

so 是用c 或c++ 写的 提供给java调用的 库 相当于dll

so存放位置
apk压缩包下的 lib文件夹里
里面有各种平台的文件夹
那么我们是要分析哪个文件夹下的so呢
一般来说 我们要分析的是
armeabi-v7a 文件夹里的so

java里 加载so库代码
例如:
package com.homelinkndk.lib;

public class JniClient
{
static
{
System.loadLibrary(“HomeLinkNdk”); //这里加载libHomeLinkNdk.so 这个so库
}

public static native String GetAppId(); //这是在java中声明的
libHomeLinkNdk.so 这个so库 里的 GetAppId 这个函数

public static native String GetAppSecret();
}

java里加载so库 加载器 通过cpu架构 到lib文件夹下去找对应的so

so文件编码规则是 “lib”+文件名+.so
java在调用so库 函数时 首先要声明
public static native String GetAppId();
public static native String GetAppSecret();
这样的声明
带有native声明的函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值