[外挂3] 编程读出坐位号
a、远程读取进程数据
b、打开远程进程
c、读取远程进程数据
首先百度一个cheat engine软件,自学一下很简单
1 API函数介绍 2 1、FindWindow //获取窗口句柄 3 2、GetWindowThreadProcessId //获取窗口进程ID 4 3、OpenProcess //打开指定进程 5 4、ReadProcessMemory //读指定进程 内存数据 6 游戏进程名: 7 游戏窗口标题: 8 HWND FindWindow( 9 LPCTSTR lpClassName, // NULL 忽略 10 LPCTSTR lpWindowName // 窗口标题 11 ); 12 13 BOOL ReadProcessMemory( 14 HANDLE hProcess, // 进程句柄 15 LPCVOID lpBaseAddress, 16 // 基址0x00B8D8E0 17 LPVOID lpBuffer, // 存放数据缓冲区 18 DWORD nSize, // 要读取数据的字节数 19 LPDWORD lpNumberOfBytesRead 20 // 实际读取的字节数 21 );
在VC代码里添加座位号的变量m_num 类型是UINT,新增一个按钮
1 void CFewDlg::OnButton2()//读取坐标号 2 { 4 //1、FindWindow //获取窗口句柄 5 //2、GetWindowThreadProcessId //获取窗口进程ID 6 //3、OpenProcess //打开指定进程 7 //4、ReadProcessMemory //读指定进程 内存数据 8 HWND gameh=::FindWindow(NULL,"井字棋");//获取窗口句柄 9 //获取窗口进程ID 10 DWORD processid; 11 ::GetWindowThreadProcessId(gameh,&processid); 12 HANDLE processH=::OpenProcess(PROCESS_ALL_ACCESS,false,processid); //打开指定进程 13 //读指定进程 内存数据 14 DWORD byread; 15 LPCVOID pbase=(LPCVOID)0x03F8EEA0;//读取当前的指针,强制转换为LPCVOID指针 16 LPVOID nbuffer=(LPVOID)&m_num; //保存当前的指针,强制转换为LPVOID指针 17 ::ReadProcessMemory(processH,pbase,nbuffer,4,&byread); 18 UpdateData(false); //更新变量的值到 编辑框 19 }
第15行的0x03F8EEA0是从CE中获得的一个地址:
所以结果为55
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?