2019独角兽企业重金招聘Python工程师标准>>>

源地址:http://hi.baidu.com/probill/blog/item/1d07d11efbd641f01ad576f3.html

网络游戏.每一个数据比如你的血值.MP 值.怪的血值..在内存中是以16进制的形式存放的.而显示给我们看的是10进制的形式显示的,,[16进制转就是123456789ABCDEF,好比 十进制的0123456789,逢16进1,十进制是逢十进1,不想算可以用windows自带的计算器,在附件中有]

网 络游戏几乎全是动态内存存放[大话战国居然不是.那天写辅助工具时发现的],,就是每上线一次,数据在内存中分配位置会变,但是.数据间地址的差值是不变 的.就是所谓的偏移量..我们要做的工作就是要让动态的,转换成静态的,只要找到一个就成了.别的根据偏移量可以知道.步骤如下:

1.我 们进游戏.首先要做的就是找动态内存地址[我以HP值举例],找动态内存的工具软件很多,我推荐金山游侠,FPE,CE,GE等...软件用法很简单.. 就好比你现在的HP值是1000.你先定位好程序.输入1000搜索,会搜到一串地址..然后让自己的血值变(比如穿件加HP的装备,比如是加了50 血),再搜1050,这样试几次就找到了唯一的动态内存地址.[虽然唯一,但一下线就会变的],第一步工作完全了...

2.然后我们要用到调试工具设断点,调试工具很多,比如OD或softice等,我以softice举例:
比 如我们搜索到HP的动态地址是044321A7..我们按CRTL+D呼出SOFICE..下命令设断点BPM 044321A7 W 然后按F5退出进游戏..只要HP值一变.就会跳出调试的界面.比如说位置跳到了001B:0047EB17 mov eax,[edx+000000fc]处..其中..edx是基值[也可以是esi等等],000000fc是一个固定的地址偏移量,每次进游戏在变的就 是基值中的数值.

3.到这..有多种方法可以求得静态地址..一种就是内存注入的方法.网上有很多这类的资料..主要是太麻烦..我就不 写了.我讲我自己的方法.我是用到指针的指针的思想..就是.我们的HP值是存放在一个动态内存地址中..地址其实也是数据..地址也是存放在地址中 的..当然.要基值的地址..所以我们要做的就是找存放基值地址的地址,可以用金山等软件搜索到..不过地址是16进制的..所以要转换成10进制.再找 存放基值地址的地址..比如说找到011076EC.好了.我们的工作完成了...现在就到了怎么写读语句..用C语言写起来很简单..用VB也可以 写..[别人说VB没指针.但并不代表不能用].因为按键是VBS语言.那我就用VB写..当然.我要调用WIN32 API函数

VB调 用API要申明,如下:Ddeclare Function ReadProcessMemory Lib "kernel32" (ByVal hProcess As Long, lpBaseAddress As Any, lpBuffer As Any, ByVal nSize As Long, lpNumberOfBytesWritten As Long) As Long
dim edx as long
dim hp as long
ReadProcessMemory nOK, ByVal &H011076EC, edx, 4, 0
ReadProcessMemory nOK, ByVal edx+000000fc, hp, 4, 0
就这样两条语句..hp中的数值就是我们的血值了..非常精准的可以得到..比如我血有1000点.我要在666点时加血..你就可以if hp<666 then keypress "加血的按键"

补充一点..搜索基址的地址是会搜到不少个的..但是一般来说..第一个就是...

------------------------------------------------------------------------------------------------------------------------------

源地址:http://www.wgx4.com/article/html/257.html

从游戏中得到动态内存数据  
            作者:sbsummer  
    刚才我玩了几把疯狂坦克,输了好几盘,觉得无聊就搞搞这个,下面开始说说如何得到游戏中的动态数据(地址改变),以得到疯狂坦克中坦克X坐标为例 
            ------------------------------------------------------------------------------ 
            工具: 
            SoftICE动态调试程序,游戏修改工具(金山游侠),反汇编(W32Dasm),Hex Workshop 
            ------------------------------------------------------------------------------ 
            一、找到内存中坦克X坐标 
            用金山游侠搜索,方法如下(金山游侠的使用我就不说了) 
            把坦克往左移动一些,就搜索“减少”;坦克往右移动,就搜索“增大” 
            反复搜索将会找到一个地址(当然其他游戏可能不止一个),这里是08BFAACC 
            注:动态的内存分配就是下次你如果再次搜索,地址将不再是08BFAACC  
            二、找到那条代码修改了这个数据(X坐标) 
            加载 SoftIce 
            在游戏状态 Ctrl+D 调出SoftIce,输入 BPM 08BFAACC W,这里的W表示如果这个地 址被写将中断 
            回到游戏,移动坦克,左移一下,程序中断,SoftIce指向的上面一句是 
            004640B3 MOV DWORD PTR [ESI+000001A4],EAX 
            这句就是修改坦克坐标的代码,当然右移也能找到一句,这里就不重复了

三、修改程序使动态的数据变成静态 
            这里说点题外话,修改程序包括两种,一种是直接修改程序,一种是修改内存中的程序(内存补丁),这里由于我懒,所以用了第一种 
            修改程序: 
            疯狂坦克程序存在Fortress2.dat当中,如果你把这个文件改名为EXE文件一样可以运行,这里我们就把他修改成Fortress2.exe 
            打开W32Dasm反汇编,SHIFT+F12跳到004046B3,你看到这几行 
            004046B3 8986A4010000 MOV DWORD PTR [ESI+000001A4],EAX 
            004046B9 8B8644020000 MOV EAX,DWORD PTR [ESI+00000244] 
            004046BF C744241001000000 MOV [ESP+10],00000001 
            刚才我们说了004046B3是修改X坐标的那条语句,现在我们要让他每次修改完程序就能够把X坐标存储到一个固定的地址 
    现在要让它运行到这里就JMP到一个我们自己的代码的地方,于是在程序的尾部我们找到一段空白的区域00465A52,于是我修改004046BF为代码 JMP  00465A52,机器码为E98E130600,因为这句的长度不够以前的那句长,所以要加入几个NOP,机器码为90,所以我们打开HEX  Workshop修改程序,CTRL+G跳到位移为000046BF的地方,看到了C744241001000000,我们把它修改为E98E130600909090,现在程序将一运行到这里就跳到00465A52运行我们的代码。

四、实现我们自己的代码,然后跳回 
            我们的代码要做的是把动态变成静态, 
            PUSH EAX 
            MOV EAX,[ESI+000001A4] 
            MOV [00470000],EAX 
            POP EAX 
            JMP 004046C7 
            这样这个数值无论运行多少次,只要你移动(当然右移也要修改)就能在00470000中找到X坐标,这段机器码为50 8B86A4010000  
            A300004700 58 E95BECF9FF 
            忘了说刚才我们把004046BF替换掉的那句MOV [ESP+10],00000001也必须加上,所以打开HEX  
            Workshop,CTRL+G跳到00465A52,修改加入 
            C744241001000000 50 8B86A4010000 A300004700 58 E95BECF9FF 
            这样动态数据就变成了静态

------------------------------------------------------------------------------

现在回顾一下 
            首先搜索坐标地址 
            找到改变这个地址的代码 
            修改代码让他跳到自己的代码中运行 
            在程序的空白段加入自己的代码,当然要补上被替换了的那句,还有修改了寄存器,必须先PUSH,再POP 
            下面的工作就是写一个程序读取这个地址了,我用VC写了一个,顺便贴一下关键代码

------------------------------------------------------------------------------ 
            CProcess m_process; 
            bool m_ret=m_process.FindProcess("FortressII"); 
            if (m_ret) 
            { 
            BYTE tank1xL = m_process.ReadByte(0x00470000); 
            BYTE tank1xR = m_process.ReadByte(0x00470001); 
            WORD tank1x = tank1xL+tank1xR*256; 
            temp = tank1x; 
            str.Format("%d",temp); 
            m_tank1x=str;  
            UpdateData(FALSE); 
            return TRUE; 
            } 
            else return FALSE;

-----------------------------------------------------------------------------

CProcess是一个我编写的游戏修改类,以下是部分函数代码:

HANDLE CProcess::OpenProcess(char *p_ClassName, char *p_WindowTitle) 
            { 
            HWND hWindow; 
            DWORD pid; 
            hWindow = FindWindow(p_ClassName, p_WindowTitle); 
            if (hWindow) { 
            GetWindowThreadProcessId(hWindow, &pid); 
            return ::OpenProcess(PROCESS_ALL_ACCESS, false, pid); 
            } 
            return NULL; 
            } 
            bool CProcess::FindProcess(char *p_WindowTitle) 
            { 
            if (m_hProcess == NULL) { 
            m_hProcess = this->OpenProcess(NULL, p_WindowTitle); 
            if (m_hProcess) 
            m_bGameRunning = true; 
            return m_bGameRunning; 
            } 
            else 
            return false; 
            } 
            BYTE CProcess::ReadByte(DWORD p_Address) 
            { 
            DWORD bytes; 
            BYTE tmpValue; 
            if (m_bGameRunning) { 
            if (ReadProcessMemory(m_hProcess, (void*)p_Address,  
            (void *)&tmpValue, 1, &bytes) == 0) 
            return 0; 
            else 
            return tmpValue; 
            } 
            return 0; 
            }

-----------------------------------------------------------------------------

转载于:https://my.oschina.net/u/2260184/blog/540570

游戏外挂内存数据读取相关推荐

  1. 易语言游戏基址内存数据CEAA自动汇编脚本注入及CALL的调用

    对于汇编基础稍弱的同学来说,CEEAA自动汇编是一个部错的选择,以CE为工具,以脚本注入为主,采用CEAA自动汇编,利于易语言调用自动 汇编脚本注入游戏,实战了各种汇编技巧,易语言注入调用汇编的各种方 ...

  2. Unity游戏开发——Excel数据读取到游戏中

    C# Unity游戏开发--Excel中的数据是如何到游戏中的 (一) 引言 现在做游戏开发的没有几个不用Excel的,用的最多的就是策划.尤其是数值策划,Excel为用户提供强大的工具,各种快捷键, ...

  3. 易语言编程-手把手教你解除游戏保护-让CE可搜索读写游戏进程内存数据

    1.  游戏进程为什么无法读写内存数据,CE工具为何不能搜索数据? 答案:因为被保护起来了 2.  游戏图标为什么不显示? 答案:因为被保护起来了 3.    如何解除游戏进程保护,从而CE工具 以及 ...

  4. 使用java来写一个游戏外挂-内存修改程序(辅助-开篇)

    很久以前研究过如何使用java写一个内存读写的程序,但是java都是知道的 它是在虚拟机上进行运行的,所以没办法进行内存的读写 所以用到了jan来执行windows自带的 kernel32.dll程序 ...

  5. 2019最新C/C++游戏外挂编程项目实战(完整)

    课程目录: 小节1 基本概念 32:46          小节2 游戏资源提取及修改 31:41          小节3 CE&OD找地址 31:59          小节4 剩余时间地 ...

  6. 编写贩卖《和平精英》游戏外挂,5人被判刑;苹果推出轻App码;Firefox 84.0发布|极客头条...

    整理 | 郑丽媛 头图 | CSDN 下载自东方 IC 快来收听极客头条音频版吧,智能播报由出门问问「魔音工坊」提供技术支持. 「极客头条」-- 技术人员的新闻圈! CSDN 的读者朋友们早上好哇,「 ...

  7. 极客日报第 31 期:编写贩卖《和平精英》游戏外挂,5人被判刑;苹果推出轻App码

    文章目录 互联网快讯 程序员专属 Github 每日精选 CSDN 社区优质博文精选 互联网快讯 1.编写贩卖<和平精英>游戏外挂,湖北襄阳 5 人被判刑 据 "湖北高院&quo ...

  8. 干货!什么是游戏外挂,外挂的种类及实现原理

    外挂,原指一切用来破坏游戏程序正常游戏数据和逻辑的工具或破解版.比如可以修改游戏内存数据的修改器,又比如可以修改网络数据包的抓包工具.这类外挂或多或少会影响游戏的内存数据.文件数据.网络数据,甚至代码 ...

  9. 数据读取速度达1.5G/s,UFS 2.1存储技术曝光

    目前最快的是苹果NVME,当然UFS2.1也不差 iPhone6s与iPhone6s Plus在硬件的规格上有了很大的提升,但是它们身上的变化远没有苹果在发布会上所提到的A9处理器.1200万摄像头以 ...

最新文章

  1. 智能电视验收测试软件,验收测试
  2. transfer 全平台Windows linux mac配置文件转换工具
  3. asp.net中page对象生命周期和各事件执行顺序
  4. Linux虚拟文件系统解析
  5. HDFS集中式缓存管理(Centralized Cache Management)
  6. 【2018.10.20】noip模拟赛Day3 二阶和
  7. WebRTC 音视频开发之路
  8. 云中计算将软件服务外包带入3.0时代
  9. grubbs检测c语言,Grubbs算法检测离群值
  10. 在Linux下安装和使用MySQL(转)
  11. 基于SSM的小区物业管理系统(附源码+论文)
  12. 游戏-安卓渠道包提审至上线流程
  13. win10时间不准_安卓机时间突然变慢10分钟?移动发布回应
  14. 【电脑自动关机】开机后Mysql再也启动不起来了。问题解决
  15. python实现三角形面积计算
  16. 58同城android客户端手机号码解密方法
  17. vi编辑器终端程序的运行(hello world)
  18. 为TreeView正色
  19. import和require
  20. 为什么只有好超市,才敢卖熟牛油果?

热门文章

  1. 【QT】Qtcreator常用快捷键
  2. VUE 查找数组中符合条件的对象
  3. 机器学习第四课:SVM前置知识点(凸优化问题)
  4. HDLBits第十四章练习及答案3
  5. python实现Excel多行多列的转换
  6. C语言中双下划线__的作用
  7. hdmi网线延长器_HDMI单网线延长器50米高清传输解决方案
  8. android在root权限下实现apk的静默卸载,静默安装,重启
  9. 征战星辰大海,从这里开始
  10. 网狐荣耀需要什么服务器系统,网狐荣耀服务器负载均衡