windows – WriteProcessMemory ERROR_PARTIAL_COPY 299
发布时间:2020-12-14 02:16:12 所属栏目:Windows 来源:网络整理
导读:我正在尝试写入另一个进程的内存,我以38h的权限(VM_OPERATION,VM_READ,VM_WRITE)打开它,然后我使用VirtualProtectEx和权限4h(PAGE_READWRITE),但我也尝试了PAGE_EXECUTEREADWRITE – 稍后同样的错误. 然后我调用ReadProcessMemory,并成功读出修复地址的值.
我正在尝试写入另一个进程的内存,我以38h的权限(VM_OPERATION,VM_READ,VM_WRITE)打开它,然后我使用VirtualProtectEx和权限4h(PAGE_READWRITE),但我也尝试了PAGE_EXECUTEREADWRITE – 稍后同样的错误.
然后我调用ReadProcessMemory,并成功读出修复地址的值. 有谁知道如何解决这个问题? 编辑:已解决 – 没有通过缓冲区写入作为参考,但作为一个值 解决方法
WriteProcessMemory给出错误ERROR_PARTIAL_COPY 299,因为第三个参数lpBuffer需要是一个指针.特别是指向本地缓冲区的指针,该缓冲区包含您要写入目标进程的数据.例如,缓冲区是一个整数,如:
int x = 5; 然后你将使用& x作为lpBuffer参数. &安培;是“运算符的地址”,它返回指向变量的指针. 通常,如果您没有为此参数传递指针,则会出现编译器错误.无论如何,ERROR_PARTIAL_COPY意味着并非源缓冲区中的所有字节都写入目标进程.这可能由于多种原因而发生,特别是如果lpBuffer参数未指向具有正确权限的已提交内存地址.如果你搞砸了WriteProcessMemory的第二个参数也一样 使用VirtualProtectEx获取目标内存页面的写入权限也是我在此处所做的建议步骤: void PatchEx(HANDLE hProcess,char* dst,char* src,int size) { DWORD oldprotect; VirtualProtectEx(hProcess,dst,size,PAGE_EXECUTE_READWRITE,&oldprotect); WriteProcessMemory(hProcess,src,NULL); VirtualProtectEx(hProcess,oldprotect,&oldprotect); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- windows-server-2008-r2 – 监视服务器上IOPS的实用程序
- windows系统java.nio.channels.FileChannel#transferTo传输
- Windows上的cocos2d-x 3.x:如何更改游戏窗口的大小?
- 使用.NET 4.5编写的软件需要什么版本的.NET运行时?
- windows-server-2008 – 本地组策略在Dc中做了什么?
- windows – 命令行web浏览
- windows-server-2008 – Server 2008 R2启动时间为2小时.现
- window 10 npm install node-sass报错
- windows – Hook进程
- 汇编 – 我的.exe程序不是我的预期
推荐文章
站长推荐
热点阅读