ASLR 根据什么逻辑更改文件汇编代码上的内存地址?

问题描述

我正在使用 OllyDbg 修补一个 exe 文件,我在两个位置以这种方式访问​​特定内存地址 MOV EAX,DWORD PTR DS:[00DE3DA0]。第一个位置是我在文件中间某处替换的指令处,另一个位置在最底部,那里有一些我可以用于新指令的空白空间。我的问题是在 ASLR 发生后/Windows 重新启动后,底部指令的内存地址不会根据新的地址布局更改,因此我的读取将不正确,但在其他位置,地址将自动设置为正确一个由 ASLR 和我的代码将始终在那里工作。另外我的最新观察是,如果我要替换的指令包括读取/写入 DS 中的其他内存地址(如 DS:[xxxxxxxx]),这种内存再生只会发生在我的代码中。

我正在寻找 ASLR 决定重新生成地址的逻辑中的信息?有没有可能让我的底层代码像上面那样重新生成

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)