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


原文地址:https://blog.csdn.net/qq_36301061/article/details/135682549
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/846922

相关文章

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法

《golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法》:本文主要介绍golang获取当前时间、时间戳和时间字符串及它们之间的相互转换,本文通过实例代码给大家介绍的非常详细,感兴趣... 目录1、获取当前时间2、获取当前时间戳3、获取当前时间的字符串格式4、它们之间的相互转化上篇文章给大家介

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA