+ -
当前位置:首页 → 问答吧 → 高级语言如何实现地址偏移呢?

高级语言如何实现地址偏移呢?

时间:2010-12-17

来源:互联网

比如我在 OD中找到基址是 0003f900
然后用 dd [[0003f900+1c]+20]+450 得到了 我需要的数据模块地址
 但是 在C++中 如何才能实现地址偏移呢?
HWND gameh=::FindWindow(NULL,"Element Client");//获取窗口句柄
DWORD processid;//获取窗口进程ID
::GetWindowThreadProcessId(gameh,&processid);
HANDLE processH=::OpenProcess(PROCESS_ALL_ACCESS,false,processid);
DWORD byread;
LPCVOID pbase=(LPCVOID)(0x009d3f00);//读取基址、、这里是基址
  LPVOID nbuffer=(LPVOID)&m_role_xue;
  ::ReadProcessMemory(processH,pbase,nbuffer,4,&byread);//读内容
  ::ReadProcessMemory(processH,(LPVOID)(&nbuffer+0x1c),nbuffer,4,&byread);
  ::ReadProcessMemory(processH,(LPVOID)(&nbuffer+0x20),nbuffer,4,&byread);
::ReadProcessMemory(processH,(LPVOID)(&nbuffer+0x450),nbuffer,4,&byread);
UpdateData(false);

我这样实现 找到的地址不对
请帮我看看?如何实现 [[0003f900+1c]+20]+450

作者: mayuan520   发布时间: 2010-12-17

真复杂

作者: zhuyi108   发布时间: 2010-12-17

热门下载

更多