我意识到我获取正确baseaddress
的版本是错误的
Process[] iexp = Process.GetProcessesByName("Solitaire");
if (iexp.Length == 0) {
//EXIT
}
Process internet = iexp[0];
uint baseAddress = (uint)internet.MainModule.BaseAddress.ToInt64();
但baseaddress
错误
我也看了MSDN,但this代码很奇怪,给了我一个无限循环。
我希望你能帮助我,因为我找不到任何例子。
编辑:
ReadProcessMemory(readHandle, ((IntPtr)(((baseAddress) + 0x14) + 0x50)), bytes, (UIntPtr)4, ref rw);
我在这里制作了桌面图像。 我真的很困惑,也许有人知道我犯了什么错误。 http://i.stack.imgur.com/50lva.jpg
答案 0 :(得分:2)
如果你想要我想你想要的东西,我只能想到几种方法,但它们都不是.NET内置的......
使用P / Invoke返回启动可执行文件的基址。
[DllImport("kernel32.dll")]
public static extern IntPtr GetModuleHandle(string lpModuleName);
返回包含MyClass
的可执行文件的基址Marshal.GetHINSTANCE(typeof(MyClass).Module)
使用以下命令返回当前模块的句柄:
Marshal.GetHINSTANCE(this.GetType().Module)