uniref

uniref 是一个辅助分析 Unity 应用的框架。它可以帮助您获取 Unity 应用中的类、方法、成员变量等的反射信息,让您实时地查看和操作它们。 您可以将您的一些分析结果借助本框架转化为少量的 Python 代码,在一定程度上方便您进行 Unity 应用的插件开发。

uniref 同时支持 MonoIL2CPP 两种脚本后端(Unity scripting backend)。

Note

目前 uniref 支持分析:

  • Windows x86 64 位操作系统上运行的 32 / 64 位 Unity 应用

  • Android ARM 架构上运行的 32 / 64 位 Unity 应用

安装

uniref 需要 Python 3.7+(64 位)的运行环境,您可以通过 pip 完成安装:

pip install -U uniref

示例

下方给出了一段使用 uniref 框架完成的代码,其解决了 MRCTF2021 的一道逆向赛题。

 1from uniref import WinUniRef
 2
 3ref = WinUniRef("GameHack.exe")
 4class_GetFlag = ref.find_class_in_image("Assembly-CSharp.dll", "Platformer.Flag.GetFlag")
 5class_GetFlag.find_field("goHome").value = True
 6class_GetFlag.find_field("findAlien").value = True
 7class_GetFlag.find_field("eatCookie").value = True
 8
 9method_EatTokenUpdateKey = class_GetFlag.find_method("EatTokenUpdateKey")
10for i in range(105):
11    method_EatTokenUpdateKey()

运行

对于 Windows 应用(exe),直接运行 Python 脚本即可。

Note

如果目标进程是以管理员权限启动的,那么请保证本框架运行在管理员权限下。即必要时,需要使用管理员权限运行 Python。

对于 Android 应用(apk),需要保证 frida 已可以在您的设备上工作。 最常用的方法是在设备上运行 frida-server,其他方式详见 frida官方文档