首页 > 其他分享 >frida stalker

frida stalker

时间:2023-01-30 18:12:39浏览次数:32  
标签:sub regs module base stalker var frida jni

//对arm64比较友好,arm32的可能崩溃
function call_1CFF0(input_str) {
    var base_hello_jni = Module.findBaseAddress("libhello-jni.so");
    var sub_1CFF0 = new NativeFunction(base_hello_jni.add(0x1CFF0), "int", ["pointer", "int", "pointer"]);
    // var input_str = "0123456789abcdef";

    var arg0 = Memory.allocUtf8String(input_str);
    var arg1 = input_str.length;
    var arg2 = Memory.alloc(arg1);
    sub_1CFF0(arg0, arg1, arg2);

}

function get_diff_regs(context, pre_regs) {
    //pre_regs是调用之前的寄存器
    var diff_regs = {};
    // console.log(Object.keys(JSON.parse(JSON.stringify(context))));
    for (const [reg_name, reg_value] of Object.entries(JSON.parse(JSON.stringify(context)))) {
        if (reg_name != "pc" && pre_regs[reg_name] !== reg_value) {
            pre_regs[reg_name] = reg_value;
            diff_regs[reg_name] = reg_value;
        }
    }
    return diff_regs;
}

function StalkerTrace() {
    var base_hello_jni = Module.findBaseAddress("libhello-jni.so");
    var sub_1CFF0 = base_hello_jni.add(0x1CFF0);
    console.log(sub_1CFF0);
    var module_hello_jni = Process.findModuleByName("libhello-jni.so");

    var module_start = module_hello_jni.base;
    //模块结束地址= base+size
    var module_end = module_hello_jni.base + module_hello_jni.size; 
    var pre_regs = {}

    Interceptor.attach(sub_1CFF0, {
        onEnter: function (args) {
            this.arg0 = args[0];
            this.arg1 = args[1];
            this.arg2 = args[2];
            //当前线程id
            this.tid = Process.getCurrentThreadId();
            // 只记录当前线程的指令
            Stalker.follow(this.tid, {
                events: {
                    call: false, // CALL instructions: yes please

                    // Other events:
                    ret: false, // RET instructions
                    exec: true, // all instructions: not recommended as it's
                    //                   a lot of data
                    block: false, // block executed: coarse execution trace
                    compile: false // block compiled: useful for coverage
                },
                // onCallSummary(summary) {
                //     // 打印obj的对象
                //     console.log("onCallSummary:", Object.entries(summary));
                // },
                // onReceive(events) {
                //     // console.log(Stalker.parse(events))
                //     for (const [index, value] of Object.entries(Stalker.parse(events))) {
                //         if (value.indexOf("exec") >= 0) {
                //             var address = value.toString().split(",")
                //             var addr = address[1];
                //             var module = Process.findModuleByAddress(addr);
                //             if (module) {
                //                 //减去模块的基址,求得相对偏移ptr(addr).sub(module.base)。
                //                 //这里打印了 所有函数执行的地址
                //                 //Instruction.parse打印出当前指令,如果需要看里面的内容就使用transform方法。
                //                 console.log("onReceive:", module.name + "!" + ptr(addr).sub(module.base), Instruction.parse(ptr(addr)));
                //             }
                //         }

                //     }
                // },
                transform(iterator) {
                    let instruction = iterator.next();
                    do {
                        const startAddress = instruction.address;
                        const is_module_code = startAddress.compare(module_start) >= 0 &&
                            startAddress.compare(module_end) === -1;
                        //在模块起始地址才打印
                        if (is_module_code) {
                            // console.log(startAddress, instruction);
                            //指令执行之后调用,context寄存器上下文
                            iterator.putCallout(function (context) {
                                var pc = context.pc; //获取pc寄存器,当前地址
                                var module = Process.findModuleByAddress(pc);
                                if (module) {
                                    //如果模块存在
                                    var diff_regs = get_diff_regs(context, pre_regs);

                                    console.log(module.name + "!" + ptr(pc).sub(module.base), 
                                        Instruction.parse(ptr(pc)),
                                        JSON.stringify(diff_regs));
                                }
                                
                            });
                        }

                        iterator.keep();
                    } while ((instruction = iterator.next()) !== null);
                }


            });

        }, onLeave: function (retval) {
            
            // 结束的时候不记录了,避免其他线程干扰。
            Stalker.unfollow(this.tid);

            console.log("sub_1CFF0:", hexdump(this.arg0, { length: parseInt(this.arg1) }),
                "\r\n", hexdump(this.arg2, { length: parseInt(this.arg1) }))
        }
    })
}


setImmediate(StalkerTrace);

标签:sub,regs,module,base,stalker,var,frida,jni
From: https://www.cnblogs.com/c-x-a/p/17076881.html

相关文章

  • frida trace
    /**raptor_frida_android_trace.js-CodetracerforAndroid*Copyright(c)2017MarcoIvaldi<[email protected]>**Frida.reJSscripttotracearb......
  • 基于 frida 实现的逆向工具包 hooker
     hooker逆向工作台:​​https://github.com/CreditTone/hooker​​hooker是一个基于frida实现的逆向工具包。为逆向开发人员提供统一化的脚本包管理方式、通杀脚本、自动......
  • Android10系统定制|frida逆向分析实战课程
    ......
  • 常用frida hook
    fridahook1、hooksystem.loadLibrary调用的so文件functionHookApp(str){Java.perform(function(){varClass=Java.use('com.App.name');v......
  • IOS-Frida-trace常用命令
    Frida-trace常用命令1、spawn-冷启动$frida-trace-U-fcom.apple.ExampleCode-m"+[NSURLURLWithString:]"2、attach-热启动$frida-trace-UF-m"+[NSURL......
  • Frida native 使用
    Interceptor使用native函数原型longtotal;template<typenameT>TaddNum(Tconstx,Tconsty){returnx+y;}extern"C"jintgetNum(JNIEnv*env,jobj......
  • frida-trace命令大全
    Frida-trace常用命令1、spawn-冷启动$frida-trace-U-f包名-m"+[NSURLURLWithString:]"2、attach-热启动$frida-trace-UF包名-m"+[NSURLURLWithStri......
  • 【iOS逆向与安全】frida-trace入门
    前言frida-trace是一个用于动态跟踪函数调用的工具。支持android和ios。安装教程请参考官网。工欲善其事必先利其器。本文将以某App为示范,演示frida-trace的各种方法在iOS......
  • Frida入门使用
    vscode环境搭建直接cloen代码,然后在vscode打开文件夹Howtocompile&load$gitclonegit://github.com/oleavr/frida-agent-example.git$cdfrida-agent-example/......
  • frida anti pthread_create
    functionanti_pthread(){varp_pthread_create=Module.findExportByName("libc.so","pthread_create");varpthread_create=newNativeFunction(p_pthread_cr......