繁体   English   中英

如何在另一个进程内存上写入?

[英]How can I write on another process memory?

我有一个地址要修改。 我有流程。 我有了新的价值。 那么现在怎么办?

// My Process
var p = Process.GetProcessesByName("ePSXe").FirstOrDefault();

// Address
var addr = 0x00A66E11;

// Value
var val = 0x63;

如何将0x63 (99) 写入另一个进程内存上的此地址?

@Harvey,从你的回答中我发现了很多:

打开、关闭和写入签名:

[DllImport("kernel32.dll")]
static extern IntPtr OpenProcess(ProcessAccessFlags dwDesiredAccess, [MarshalAs(UnmanagedType.Bool)] bool bInheritHandle, int dwProcessId);

[DllImport("kernel32.dll", SetLastError = true)]
static extern bool WriteProcessMemory(IntPtr hProcess, IntPtr lpBaseAddress, byte[] lpBuffer, uint nSize, out int lpNumberOfBytesWritten);

[DllImport("kernel32.dll")]
public static extern Int32 CloseHandle(IntPtr hProcess);

标志:

[Flags]
public enum ProcessAccessFlags : uint
{
    All = 0x001F0FFF,
    Terminate = 0x00000001,
    CreateThread = 0x00000002,
    VMOperation = 0x00000008,
    VMRead = 0x00000010,
    VMWrite = 0x00000020,
    DupHandle = 0x00000040,
    SetInformation = 0x00000200,
    QueryInformation = 0x00000400,
    Synchronize = 0x00100000
}

让我的生活更轻松的方法:

public static void WriteMem(Process p, int address, long v)
{
    var hProc = OpenProcess(ProcessAccessFlags.All, false, (int)p.Id);
    var val = new byte[] { (byte)v };

    int wtf = 0;
    WriteProcessMemory(hProc, new IntPtr(address), val, (UInt32)val.LongLength, out wtf);

    CloseHandle(hProc);
}

写入另一个进程内存:

static void Main(string[] args)
{
    var p = Process.GetProcessesByName("ePSXe").FirstOrDefault();

    WriteMem(p, 0x00A66DB9, 99);
}

尽管诸如WriteProcessMemory P/Invoke 原生函数可以完美运行,但仍存在专用于内存编辑的库,并使您能够以更简单的方式完成此任务。

使用库MemorySharp ,这可以总结为:

using(var sharp = new MemorySharp(Process.GetProcessesByName("ePSXe").FirstOrDefault()))
{
   sharp[0x00A66E11, false].Write(0x63);
}

前面的代码假定写入值的地址没有重新定位。

在 pinvoke.net 上查看WriteProcessMemory

这是 StackOverflow 上的另一个类似帖子,但他们谈论的是 C++。 您可以使用 pinvoke 执行相同操作。

您可以使用WriteProcessMemory ,但请注意,您需要打开调试权限,并且它不适用于 Vista 及更高版本中的许多安全进程。

而且你可能会用脚射击并撞到东西几次。 我建议您在执行此操作时不要运行任何重要程序。

祝你好运,你会需要它。 :)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM