写在前面
1.通过前面的文章,相信各位已经能够自己找到GNames并使用DUMP工具导出GNames了。
2.本篇文章将介绍各种所需数据的查找方法。
一、准备工作
1.CheatEngine,本篇以及后续篇幅的重要工具。
2.一个记事本,保证你能记录下关键信息。
二、代码分析/字符串关键词
a.代码分析/引用的字符串
1.首先,打开CE并附加游戏。
2.点击浏览内存/查看内存,或随便搜索一个数值选中后按下CTRL+B快捷键。
3.在浏览内存区域窗口中选择视图菜单->引用的字符串(快捷键CTRL+ALT+R)。
data:image/s3,"s3://crabby-images/ecb58/ecb5872cdc89773df067b27b28b93f1f6cd4415d" alt=""
4.如果没有打开过,会询问你是否分析代码,点击是,进行分析。
5.等待分析完成。
三.FNamePool
data:image/s3,"s3://crabby-images/712cc/712ccddd6ab98934785a9df732dcbe4bbcdbfc84" alt=""
1.代码分析完成后,按下CTRL+F键打开查找窗口,输入 Duplicated 进行查找。
2.笔者这里搜索到了一个名为:DuplicatedHardcodedName 的字符串。
3.选中搜索到的字符串,在窗口右边有一个地址,双击它:
data:image/s3,"s3://crabby-images/a0cb9/a0cb961132390f5664dc6b5f0bffc8e3c17c219c" alt=""
来到了汇编窗口:
data:image/s3,"s3://crabby-images/a5c73/a5c73685987afc0ec74be478bcf54604d0146abd" alt=""
4.现在,在当前位置(蓝色) 按下鼠标右键,选中当前函数:
data:image/s3,"s3://crabby-images/753aa/753aa474a13386216fbb671ba26a9ddf38898fcb" alt=""
data:image/s3,"s3://crabby-images/2e618/2e6181f75c026387955f8b9302ff254fae72bd8c" alt=""
5.这样,整个函数就被选中了,现在往上翻到函数顶部双击调用:
data:image/s3,"s3://crabby-images/a6cf9/a6cf95b096e4e517758b5970eb8bfbe012b07701" alt=""
来到此处:
data:image/s3,"s3://crabby-images/c83b5/c83b569bfdd50ff0335756278cf51ff6dcd05bd4" alt=""
现在,注意当前位置(CALL)的上一行,将它的地址拿出来:
data:image/s3,"s3://crabby-images/27681/27681bd495f786b2b0e1f573c7543426cf1f0e17" alt=""
扔到数据结构分析器中看一看:
data:image/s3,"s3://crabby-images/07130/07130b1644b0e50b470adb848988941115997159" alt=""
非常规律,那么这大概率就是我们需要的东西了。
1.记录地址并设置特征码
data:image/s3,"s3://crabby-images/2a3ce/2a3cebe8428794e8d462e026a459849975cefdf5" alt=""
1.选中一行后按住shift键点击要批量选中的位置,然后右键复制到剪贴板(字节+操作码) 。
2.别忘了把之前的地址也一块记录下来。
=====FNamePool=====
字符串关键词:Duplicated、DuplicatedHardcodedName
7FF77C04C600
GameBase + D20C600 -> Current FNamePool Addr.
48 8D 0D ?? ?? ?? ?? E8 ?? ?? ?? ?? 48 8B D8 C6 05 ?? ?? ?? ?? 01 0F 28 ?? ?? ?? -> Init FNamePool Signature.
DeadByDaylight-Win64-Shipping.exe+396458B - 48 8D 0D 6E808A09 - lea rcx,[DeadByDaylight-Win64-Shipping.exe+D20C600]
DeadByDaylight-Win64-Shipping.exe+3964592 - E8 C9D64702 - call DeadByDaylight-Win64-Shipping.exe+5DE1C60
DeadByDaylight-Win64-Shipping.exe+3964597 - 48 8B D8 - mov rbx,rax
DeadByDaylight-Win64-Shipping.exe+396459A - C6 05 57808A09 01 - mov byte ptr [DeadByDaylight-Win64-Shipping.exe+D20C5F8],01
DeadByDaylight-Win64-Shipping.exe+39645A1 - 0F28 44 24 20 - movaps xmm0,[rsp+20]
3.需要注意的是,特征码需要将操作码中会变动的内容以??代替。
4.尝试使用CE搜索特征码:
data:image/s3,"s3://crabby-images/ce166/ce166fa905b85307e310ee6a7640df3c33b0cf2e" alt=""
出来了4个地址,依次加入地址列表:
data:image/s3,"s3://crabby-images/c2576/c257631224839cb32b4ad437173cc0ccfb6f8020" alt=""
5.需要注意的是加入地址列表后需要编辑地址,将其地址后面+3(因为特征码前面3个字节我们是不需要的,只需要看里面的地址),并修改类型为4字节。
6.结果如下:
data:image/s3,"s3://crabby-images/334f6/334f6efdc52f72acf8111fc7d50576753bac3794" alt=""
- 使用FNamePool Addr:
cpp
NamePool = (FNamePool*)(game_base + 0x0D20C600);
四、FUObjectArray
1.同样的,与查找FNamePool一样的方法。
2.关键词:ShowPendingKills,查找后出现结果:
data:image/s3,"s3://crabby-images/14c5d/14c5dd549aad9f43c51c9c54dec1a0b95d40cdaa" alt=""
出现了2个地址,可以依次尝试,双击第一个地址后来到此处:
data:image/s3,"s3://crabby-images/ee76b/ee76b5a2ae66e6f8251421428ac0f2e3967a448f" alt=""
- 这时候,我们要向下翻:
data:image/s3,"s3://crabby-images/ab7a6/ab7a65647675f43354e8eefccb81d8c7d93eaaa5" alt=""
1.记录地址并设置特征码
1.同样的,记录下它的地址以及操作码等信息:
data:image/s3,"s3://crabby-images/f6c18/f6c1840707af4c8a770aca8bf28716c394e45a97" alt=""
data:image/s3,"s3://crabby-images/f8f1b/f8f1b547d33713e1b9a075c3ab9a84a5ae95fb23" alt=""
2.使用CE搜索特征码看看:
data:image/s3,"s3://crabby-images/d4f46/d4f463e7de95046d9f9951e0b956a813509ceb42" alt=""
=====FUObjectArray=====
字符串关键词:ShowPendingKills
7FF77C0A4C30
GameBase + D264C30 -> Current GObjects Addr.
48 8B 0D ?? ?? ?? ?? 48 98 4C 8B 04 D1 -> GObject Signature.
DeadByDaylight-Win64-Shipping.exe+7B550C0 - 48 8B 0D 69FB7005 - mov rcx,[DeadByDaylight-Win64-Shipping.exe+D264C30]
DeadByDaylight-Win64-Shipping.exe+7B550C7 - 48 98 - cdqe
DeadByDaylight-Win64-Shipping.exe+7B550C9 - 4C 8B 04 D1 - mov r8,[rcx+rdx*8]
- 使用FUObjectArray Addr:
cpp
ObjectArray = (TUObjectArray*)(game_base + 0x0D264C30);
五、PostRender
1.这个东西其实就是引擎自身的绘制。
2.关键词:LoadingMessage,相似的流程:
data:image/s3,"s3://crabby-images/dbaf3/dbaf30a7f2ac36c1a0ee7cc035dfcb2ea6d226f8" alt=""
双击地址来到此处:
data:image/s3,"s3://crabby-images/981f1/981f155201f1156b7e3d8d706683c1bf5ae6c974" alt=""
选中整个函数:
data:image/s3,"s3://crabby-images/22abc/22abc52bb3d3723055bd3c2a43e3469c6f4964fa" alt=""
3.来到头部以后,下一个断点等待断下:
data:image/s3,"s3://crabby-images/85bf6/85bf690bf15a35e855e84738e0eabb1019658132" alt=""
data:image/s3,"s3://crabby-images/c1ded/c1ded1bd6706089e3b62d347854f563364923fb6" alt=""
4.游戏断下后,注意右下角堆栈窗口,选择第一个双击过去:
data:image/s3,"s3://crabby-images/51094/510944ab8de91ec513c4e6db63fb05b74f0a247e" alt=""
跳过去后,注意上面一行:
5.这个偏移就是我们需要的东西了,记录下来并计算一下:
6.需要注意,这里是16进制。同时因为8字节的关系所以除以0x08而不是0x04。
7.得到了0x65:
=====PostRender=====
字符串关键词:LoadingMessage
DeadByDaylight-Win64-Shipping.exe+7B4B782 - FF 90 28030000 - call qword ptr [rax+00000328] -> Call PostRender.
0x328 / 0x08 = 0x65
cpp
int post_render_index = 0x65;
六、ProcessEvent
1.关键词:bad or,操作流程大同小异:
data:image/s3,"s3://crabby-images/47377/473776268fed5d37f72294dd18bb41fde6621821" alt=""
data:image/s3,"s3://crabby-images/0ed9f/0ed9fa5852b5f576b863bf41666cdeaae61f866e" alt=""
当然,这次需要往上翻,翻到哪里呢?
找红框中类似的汇编指令,向上找8次就差不多了:
data:image/s3,"s3://crabby-images/26757/26757d4b2a0b6f286bc98366db5b90c828eae93c" alt=""
第一次:
data:image/s3,"s3://crabby-images/cb324/cb324041f3f7939e55b448003ef0d47a6395825e" alt=""
第二次:
data:image/s3,"s3://crabby-images/d3caa/d3caaa37d63d915249fffdfcd4a1349e92b4edf4" alt=""
第三次:
data:image/s3,"s3://crabby-images/399d2/399d2fddb82b8cf4c58bff290f1b4d4d81fcaab7" alt=""
第四次:
data:image/s3,"s3://crabby-images/76446/76446d8622a11200113acc05ef4a9609e9094834" alt=""
第五次:
data:image/s3,"s3://crabby-images/5ea21/5ea21702d46ddbdf6fd93c094ee4d36508d54cea" alt=""
第六次:
data:image/s3,"s3://crabby-images/e23e7/e23e7aab1854e4af6d81b579f0f82dddb6ae8b4a" alt=""
第七次:
data:image/s3,"s3://crabby-images/20427/2042703033fe289992faf8b39fa221d6d5507c43" alt=""
第八次:
data:image/s3,"s3://crabby-images/7f5a3/7f5a315589107af6ae7efa31e72afddf344c2ab8" alt=""
data:image/s3,"s3://crabby-images/02a83/02a8375bfded4c6dc1c8716cf37a8721ec0eb1b2" alt=""
这就找到了,同样的,记录下来计算:
data:image/s3,"s3://crabby-images/a6e1a/a6e1aa4c46a6936e1cb32f2c4c23e5e1b6502173" alt=""
得到结果为0x44。
cpp
int process_event_index = 0x44;
=====ProcessEvent=====
字符串关键词:bad or
DeadByDaylight-Win64-Shipping.exe+5FEE840 - FF 90 20020000 - call qword ptr [rax+00000220] -> Process Event Vtable Offset.
0x220 / 0x08 = 0x44
七、UWorld
cpp
//Init World
world = *(UWorld**)(game_base + 0x00000000); //未知的World偏移
1.首先需要下载游戏对应版本的UE4源代码,怎么下载在前文中有稍微提及,具体可以查看EPIC官网。
2.使用IDA+源码的方式找到UWorld。
3.由于篇幅限制,此处不再过多解释。