纯记录贴,怕下次自己忘了。
目标:steam锁国区某日游,因无中文语言,所以想做一下汉化。
使用工具:CPP2IL  https://github.com/SamboyCoding/Cpp2IL
Il2CppInspector
AssetStudioGUI
dnspy  ida   x64dbg  用到的工具比较多

一、先找语言文件
先打开AssetStudioGUI
记录一次U3D il2cpp游戏逆向解包
直接加载游戏文件目录,等他跑一小会,随便搜搜关键字筛选一下看看
记录一次U3D il2cpp游戏逆向解包记录一次U3D il2cpp游戏逆向解包
能看到多语言文件都是加密过的,先右键导出个英文的文件准备开干。
二、解包GameAssembly.dll
下载好Cpp2il,填上bat命令行,一键导出,或者使用Il2CppInspector。
命令行:Cpp2IL.exe  --game-path="D:\Program Files (x86)\Steam\steamapps\common\Yu-Gi-Oh!  Master Duel" --exe-name="masterduel"
经过漫长无比的等待后
cpp2il文件目录下会输出若干文件
记录一次U3D il2cpp游戏逆向解包
三、分析Assembly-CSharp.dll
拖进dnspy可以看到类似这样,看不到函数内部,只能看到函数名,够用了,开始找解密函数
记录一次U3D il2cpp游戏逆向解包
搜索Decrypt方法,只有一个符合,我这里已经知道这个函数就是解密函数了,所以直接拿他开整。
记录一次U3D il2cpp游戏逆向解包
记录下地址:[Address(RVA = "0x7BD270", Offset = "0x7BC470", VA = "0x1807BD270",dnspy先别关一会还有用
四、分析GetBytesDecryptionData解密函数
掏出IDA拖入GameAssembly.dll,抽根烟开始漫长的等待。跑完之后直接去00000001807BD270处F5看一下伪代码
记录一次U3D il2cpp游戏逆向解包
很简单的逻辑,在去dbg里跑一下看一眼变量。
记录一次U3D il2cpp游戏逆向解包
这里rbx+78对应的a1 + 120,拿到v5的数值,接下来写个算法就好了,其实就两行。
记录一次U3D il2cpp游戏逆向解包
记录一次U3D il2cpp游戏逆向解包
简单的运算,没啥好讲的,解密之后发现还是加密的状态,后来我仔细找了找,返回值还有一个call双击进去,复制1806ED310,dnspy搜一下字符串
记录一次U3D il2cpp游戏逆向解包
对应的应该是zlib算法里的解压函数,下载一个zlib类库看下源码
记录一次U3D il2cpp游戏逆向解包
OK,引用到项目,测试一下完活
记录一次U3D il2cpp游戏逆向解包
记录一次U3D il2cpp游戏逆向解包
标签:
记录一次U3D il2cpp游戏逆向解包

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com

评论“记录一次U3D il2cpp游戏逆向解包”

暂无“记录一次U3D il2cpp游戏逆向解包”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。