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

相关文章

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

Python Excel实现自动添加编号

《PythonExcel实现自动添加编号》这篇文章主要为大家详细介绍了如何使用Python在Excel中实现自动添加编号效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍简单的说,就是在Excel中有一列h=会有重复

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值