• frida native层读写文件


    function main(){
        write_file1()
        write_File2()
    }
    function write_file1(){
        //使用firda的自带api
        var file = new File("/data/local/tmp/mytest.dat")
        file.write("1234");
        file.flush();
        file.close();
    }
    
    function write_File2(){
        var addr_fopen = Module.findExportByName("libc.so","fopen")
        var addr_fputs = Module.findExportByName("libc.so","fputs")
        var addr_fclose= Module.findExportByName("libc.so","fclose")
        //NativeFunction 将地址创建为可调用的函数,第一个参数是函数地址,第二个参数是返回值类型,所有指针类型,包括string(char*),都是pointer
        //第三个参数就是原函数的参数列表
    
        var fopen = new NativeFunction(addr_fopen,"pointer",["pointer","pointer"])
        var fputs = new NativeFunction(addr_fputs,"int",["pointer","pointer"]);
        var fclose = new NativeFunction(addr_fclose,"int",["pointer"]);
    
        var filename = Memory.allocUtf8String("/data/local/tmp/mytest.dat"); //native层需要这样创建字符串,在java层就可以直接写字符串
        var open_mode = Memory.allocUtf8String("w+");
        var file = fopen(filename,open_mode);
    
        var buffer_str = Memory.allocUtf8String("1234")
        var ret = fputs(buffer_str,file);
        console.log("fputs ret:",ret);
        fclose(file);
    }
    setImmediate(main)
    
  • 相关阅读:
    Java实现八大排序算法
    Java实现二分查找算法
    Win10下通过IIS调试ASP程序遇到的问题和解决方案
    Nginx几种负载均衡算法及配置实例
    Java解决CSRF问题
    Nginx Https配置不带www跳转www
    面试中的Https
    面试中的DNS
    java系列视频教程下载
    关于Mysql DATE_FORMAT() 日期格式
  • 原文地址:https://www.cnblogs.com/c-x-a/p/15192821.html
Copyright © 2020-2023  润新知