frida 主动调用so native实例函数的问题

调用实例函数,第一个参数为this指针

var module=Process.getModuleByName("libart.so");
var symbols=module.enumerateSymbols();
var pretty_addr=module.getExportByName("_ZN3art9ArtMethod12PrettyMethodEb");
  
for(let i=0;i<symbols.length;i++){
    var name=symbols[i].name;
    var addr=symbols[i].address

    if(name==="_ZN3art9ArtMethod14RegisterNativeEPKvb"){
         Interceptor.attach(addr,{
            onEnter:function (args){
                var thisPointer=ptr(args[0]);          
                var native_fun= new NativeFunction(pretty_addr,"pointer",["pointer","bool"]);
                var result=native_fun(thisPointer,1);
            },
            onLeave:function (ret){    
            }
        });  
        break;  
    } 
} 

报错
Error: access violation accessing 0xd

PrettyMethod函数原型
std::string PrettyMethod(bool with_signature = true)

查看frida文档
For C++ scenarios involving a return value that is larger than Process.pointerSize, a typical ABI may expect that a NativePointer to preallocated space must be passed in as the first parameter. (This scenario is common in WebKit, for example.)

也就是说,如果c++函数的返回长度大于一个指针的大小,第一个参数必须是一个指针,用于预分配空间,
而c++的string指针长度是8个字节在这里插入图片描述
因此要这样写:

var result=Memory.alloc(3*Process.pointerSize);
var native_fun= new NativeFunction(pretty_addr,"pointer",["pointer","pointer","bool"]);
native_fun(result,thisPointer,1);
var str=result.add(2*Process.pointerSize).readPointer().readUtf8String();

因为返回值会存放在2个指针长度的偏移处,所以要加2

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Frida是一款功能强大的动态插桩框架,可以用于实时分析、修改和控制Android、iOS和Windows应用程序。它运行在主机上并与目标应用程序进行通信,可以访问和操作应用程序的内部数据和行为。 Frida主动调用是指通过Frida框架中的一些API函数,应用程序可以主动调用一些指定的函数或方法。通过主动调用,我们可以在运行时动态修改应用程序的行为,即在代码执行过程中注入自己的代码,并对应用程序进行操作。 使用Frida进行主动调用通常需要以下步骤: 1. 在主机上安装Frida,并获取目标应用程序的进程ID或进程名称。 2. 编写一个Frida脚本,通过Frida的API函数创建一个会话,并连接到目标应用程序。 3. 在会话中,使用Frida的API函数定位到要调用函数或方法,并设置好参数。 4. 使用Frida的API函数发起主动调用,并接收返回结果。 5. 处理返回结果,并根据需要进行进一步操作。 例如,在Android应用程序中,我们可以使用Frida的Java API函数来定位到某个对象的方法,并通过主动调用来触发该方法的执行。这样可以绕过应用程序中的某些限制或修改某些功能的行为。 总的来说,Frida主动调用功能为开发者提供了一种在目标应用程序中主动操作和控制的方式,通过注入自己的代码,可以实现一些特定需求或调试目的。无论是动态修改应用程序行为还是进行逆向分析,Frida主动调用功能都是非常有用的工具之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值