高级语言如何实现地址偏移呢?
时间: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
然后用 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
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28