Readprocessmemory用法
来源:互联网 发布:少儿网络英语哪个好 编辑:程序博客网 时间:2024/05/01 23:58
函数功能:该函数从指定的进程中读入内存信息,被读取的区域必须具有访问权限。
函数原型:BOOL ReadProcessMemory(HANDLE hProcess,LPCVOID lpBaseAddress,LPVOID lpBuffer,DWORD nSize,LPDWORD lpNumberOfBytesRead);
参数:
hProcess:进程句柄
lpBaseAddress:读出数据的地址
lpBuffer:存放读取数据的地址
nSize:读出的数据大小
lpNumberOfBytesRead:数据的实际大小
C#中使用该函数首先导入命名空间:
- using System.Runtime.InteropServices;
然后写API引用部分的代码,放入 class 内部
- [DllImport("kernel32.dll ")]
- static extern bool ReadProcessMemory(int hProcess, int lpBaseAddress,out int lpBuffer, int nSize, out int lpNumberOfBytesRead);
这个函数有五个参数,第一个参数是 进程句柄,由OpenProcess函数获取;第二个参数是要读出数据的地址,使用CE等辅助工具可取得;第三个参数是用于存放读取数据的地址;第四个参数是 要读出的数据大小;第五个参数是读出数据的实际大小。例如:
- IntPtr hwnd = FindWindow(null, "计算器");
- const int PROCESS_ALL_ACCESS = 0x1F0FFF;
- const int PROCESS_VM_READ = 0x0010;
- const int PROCESS_VM_WRITE = 0x0020;
- if (hwnd != IntPtr.Zero)
- {
- int calcID;
- int calcProcess;
- int dataAddress;
- int readByte;
- GetWindowThreadProcessId(hwnd, out calcID);
- calcProcess = OpenProcess(PROCESS_VM_READ | PROCESS_VM_WRITE, false, calcID);
- //假设地址0X0047C9D4存在信息
- ReadProcessMemory(calcProcess, 0X0047C9D4, out dataAddress, 4, out readByte);
- MessageBox.Show(dataAddress.ToString());
- }
- else
- {
- MessageBox.Show("没有找到窗口");
- }
如果我们读取的一段内存中的数据,我们引入部分可修改成如下:
- //二维数组
- [DllImport("kernel32.dll ")]
- static extern bool ReadProcessMemory(int hProcess, int lpBaseAddress, byte[,] lpBuffer, int nSize, out int lpNumberOfBytesRead);
- //一维数组
- [DllImport("kernel32.dll ")]
- static extern bool ReadProcessMemory(int hProcess, int lpBaseAddress, byte[] lpBuffer, int nSize, out int lpNumberOfBytesRead);
由于数组是引用传递,我们不需要写out关键字。
0 0
- Readprocessmemory用法
- Readprocessmemory用法
- Readprocessmemory用法
- ReadProcessMemory函数的用法
- C# Readprocessmemory用法
- C# Readprocessmemory用法 .
- C# ReadProcessMemory/OpenProcess/CloseHandle用法
- ReadProcessMemory
- ReadProcessMemory
- ReadProcessMemory
- ReadProcessMemory
- ReadProcessMemory
- ReadProcessMemory
- ReadProcessMemory()
- ReadProcessMemory使用
- ReadProcessMemory函数的分析
- ReadProcessMemory函数的分析
- ReadProcessMemory/C++的探索
- Android核心组件之ContentProvider(二)--创建自己的ContentProvider
- 交叉编译Mesa,X11lib,Qt opengl
- Node.js学习笔记3【核心模块--event】
- Swift_2_控制语句
- sql server port 1433 vs 1434
- Readprocessmemory用法
- Recommenderlab评估代码分析
- luasql脚本工具的安装
- 会出现段错误的几种情况
- 在8位单片机中使用Google Protobuf
- 光年无线回顾 - 所有的炒作或全部好
- 实现序列化笔记
- 大数据技术读懂球迷心声
- Swift_3_函数