微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。