74.网游逆向分析与插件开发-背包的获取-物品名称与物品编号的映射关系分析

本文主要是介绍74.网游逆向分析与插件开发-背包的获取-物品名称与物品编号的映射关系分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内容参考于:易道云信息技术研究院VIP课

上一个内容:73.网游逆向分析与插件开发-背包的获取-物品数据的初步数据分析-CSDN博客

还是打开 Cheat Engine,搜索字符串,先把名字找到

然后又两个

然后第二个好像是根据悬浮窗来的,所以不管它了,然后就还剩下一个

然后剩下的那一个内存,我们改它的字符串可以正常在游戏里显示

然后根据上一个内容里的分析,5912是HP回复或5913是MP回复,然后看是什么访问了它,鼠标放到物品上它就会访问了,然后想一下它的逻辑,从鼠标放上去以后,它首先会读物品id,读了物品id接下来就是一个运算,然后根据运算的结果显示出来,它的算法是给一个5912它一定能返回一个名称,所以原则上来讲通过字符串的读取就能找到这个运算了,然后再往前找就能找到访问物品id的地方

然后记录一下信息:C51532 与 C50D81

然后打开x96dbg,下条件断点

然后鼠标放到物品上卡主

来到下图位置就看不到物品的名字了:

然后下图红框位置的代码,与之前分析按钮名字的位置的代码相似

对比:用的都是同一个类

它可以正常返回物品名称

然后接下来找eax的值在哪来的,可以从下图看出eax的值是从下图红框函数里返回出来的,它的上一行是mov ecx,ebx,在调用函数之前有这样对ecx操作,说明ecx是一个类,下面的函数是这个类中的函数一个成员函数,然后函数调用完是add eax,60这样的操作说明有继承

然后这个函数没有参数,然后下图开头把偏移34位置的成员变量拿了出来,上一个内容中也分析过了0x34位置是物品id

然后这个ebx可能是物品的指针,然后通过 Cheat Engine 看 1FC92618+9C位置的数据,根据上一个内容中分析的偏移9C位置是物品的数量

可以看出它确实是物品指针

然后接下来分析一下现在知道的东西,首先通过物品的指针,调用了它的一个成员函数,这个函数是0x995800,通过这个函数能够得到一个新的指针,然后把这个指针+0x60位置的值传递给0x1036518类中的0x9A4640函数里,0x9A4640这个函数它返回一个SRO_String类型。

然后现在记录一下分析到的地址0x739915位置调用了0x995800函数。

然后分析一下0x995800函数,它首先获取了物品的id,然后得到一个可以获取字符串的东西,也就是说,我们连物品的地址都不需要知道,只需要知道物品的id就可以,我们随便搞个结构体,然后在结构体偏移0x34位置设置成物品id,然后就去调用 0x995800函数 或者 直接搞一个0x1036590的类,然后调用它的A2A930函数,这个函数的参数是物品id,然后把它的返回值加0x60的结果传递给0x1036518类中的0x9A640函数。

然后访问技能的时候也是会调用 0x995800 函数,通过它可以得到好多东西的地址

这篇关于74.网游逆向分析与插件开发-背包的获取-物品名称与物品编号的映射关系分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/846922

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

锐捷和腾达哪个好? 两个品牌路由器对比分析

《锐捷和腾达哪个好?两个品牌路由器对比分析》在选择路由器时,Tenda和锐捷都是备受关注的品牌,各自有独特的产品特点和市场定位,选择哪个品牌的路由器更合适,实际上取决于你的具体需求和使用场景,我们从... 在选购路由器时,锐捷和腾达都是市场上备受关注的品牌,但它们的定位和特点却有所不同。锐捷更偏向企业级和专

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

python获取当前文件和目录路径的方法详解

《python获取当前文件和目录路径的方法详解》:本文主要介绍Python中获取当前文件路径和目录的方法,包括使用__file__关键字、os.path.abspath、os.path.realp... 目录1、获取当前文件路径2、获取当前文件所在目录3、os.path.abspath和os.path.re

Spring中Bean有关NullPointerException异常的原因分析

《Spring中Bean有关NullPointerException异常的原因分析》在Spring中使用@Autowired注解注入的bean不能在静态上下文中访问,否则会导致NullPointerE... 目录Spring中Bean有关NullPointerException异常的原因问题描述解决方案总结

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

python-nmap实现python利用nmap进行扫描分析

《python-nmap实现python利用nmap进行扫描分析》Nmap是一个非常用的网络/端口扫描工具,如果想将nmap集成进你的工具里,可以使用python-nmap这个python库,它提供了... 目录前言python-nmap的基本使用PortScanner扫描PortScannerAsync异