0
点赞
收藏
分享

微信扫一扫

Unity游戏逆向学习记录01

有态度的萌狮子 2022-03-23 阅读 59

学习工具收集记录 , 关键信息记录
工具:
1、https://github.com/Perfare/Il2CppDumper
2、https://github.com/dnSpy/dnSpy
操作:
打开工具 Il2CppDumper,依次选择:libil2cpp.so,global-metadata.dat
dnSpy 拖入反编译后的 /DummyDll/Assembly-CSharp.dll

Unity游戏与Java的通信是通过UnitySendMessage()之类的函数来实现的

Objection来完成Class批量断点
objection -g com.android.settings explore
参考地址:https://www.cnblogs.com/lxh2cwl/p/14842544.html

hook偏移地址方法

function start(){
    //com.izyplay.defusethebomb.bazhang
    var arrayAddr = [0x54728C,0x547310,0x54745C,0x547DF8,0x547484,0x548218,0x547F30,0x55DF40
        ,0x679798,0x6798B4,0x687428,0x687350]; 
    var arrayName = ["AndroidDialog Create","AndroidDialog Create1","AndroidDialog init"
        ,"AndroidMessage Create","showDialog","CallStatic","showMessage","SetPressedState"
        ,"NativeDialog","NativeMessage","ToggleButton","OnClick"]; 
    
    var soAddr = Module.findBaseAddress("libil2cpp.so");
    console.error('\nsoAddr:' + soAddr + "\n");

    for (var index = 0; index < arrayAddr.length; index++) {  
        console.log("-------------------------");
        var currentAddr = soAddr.add(arrayAddr[index]);
        console.log('currentAddr:' + currentAddr);
        funcTmp(currentAddr,soAddr,index,arrayName);
        console.log("\t\t---->"+index,arrayAddr[index]+" is prepared ");  
    } 
    console.log("\n")
}

function funcTmp(currentAddr,soAddr,index,arrayName){
    Interceptor.attach(currentAddr, {
        onEnter: function(args){
            console.log("called : "+arrayName[index]+"  ----- addr : " + currentAddr.sub(soAddr) +"\n");
        },
        onLeave: function(retval){

        }
    });
}
举报

相关推荐

0 条评论