一.《传奇M》装备栏遍历的突破口

news2024/12/27 11:46:03

寻找突破口

1.首先根据大多数游戏而言,装备栏中一般记录的是装备的对象或者装备ID,那么当我们穿装备或者脱装备肯定会有相应的值在改变
2.我们就从这里入手,当穿或脱装备的时候,使用CE搜索0然后通过改变或者未改变来筛选结果
3.接下来我们操作试一试这个思路可不可以

 4.点击首次扫描,可以搜索到很多值,这个时候我们并不知道装备栏存的是对象还是ID,我们就通过改变或者未改变来筛选结果

 5.然后穿或者托装备,继续用CE搜索变动的值,因为肯定有个值在记录这个装备的信息,比如我们上面说的装备对象或者装备ID之类的

 6.当我们不断的过滤扫描后,发现结果变少了,但是还是很多,那么我们就可以在穿上或者脱下装备的情况下筛选结果数量,这里尤其注意我们穿上脱下的装备是同一个!

 7.好了,经过我们的不变筛选,最终的结果很少了,但是还有1000多个,这样也不利于我们找数据,我们也观察到在这1000多个结果中绝大多数都是类似ID而不是地址

 8.那么我们想一下会不会存的就是装备的ID呢?那么我们就需要拿到之前我们将的背包遍历中的装备ID:1C5E2DD9BCC88FD6,拿到【木剑】装备的结构体地址,我们在XDBG查看内存值,这个结构体首地址+0的偏移的地址存的值1C5E2DD9BCC88FD6就是ID

 9.这里我也开发了一套传奇M脚本SDK,我们点击背包遍历可以看到【木剑】这个装备的ID是1C5E2DD9BCC88FD6,这个ID我把他命名为CID

 10.好!确定了ID,我们直接CE搜索这个ID值,注意在穿上装备的情况下

 11.惊奇的发现,结果变为了0!!!what?弄下嘞?老师你在逗我呢?害我看那么多文字,结果不对

 12.额额额,这里我要说明下, 我们要学会培养同学们的思考问题的能力,所以我在分析正确之前必须要讲一下这个,因为绝大数同学都会这样搜索!

正确突破口

1.上面我们观察到ID是不行了,难道是对象吗?
2.经过我们搜索对象来回变动也不行,难道我们没有别的突破口呢?
3.其实是有的,还有两种方法,第一种是通过脱装备CALL来需要参数的来源,因为脱装备的流程肯定会去遍历装备栏,这种方式是最简单的,但是需要先找到CALL
4.还有一种方法是通过一种搜索值的潜规则!
5.好!既然要写好帖子那么就用最不常用的方法的给大家讲下这个潜规则是什么意思
6.他这个装备栏其实的存储规律是,当穿装备的时候才会分配内存
7.而当脱装备的时候,之前穿的时候分配的内存是不会被销毁的!
8.换一句话说我们在首次搜索未知初始值后,当穿装备才用变动的值搜索,当脱装备的时候要用未变动的值搜索!!!这里就是核心关键点!相信很多同学都不太明白这里
9.其实呢!我们还可以通过一个现象去观察到,就是这款游戏很奇怪!不知道同学们发现没?当我们穿装备的时候游戏会卡顿一下,而当我们脱装备的时候会比较流畅一点,那么我估计和我说的那个潜规则有关系,这里也只是猜测!
10.好了废话不多说我们来搜索看看,记住我说的“当穿装备才用变动的值搜索,当脱装备的时候要用未变动的值搜索”
11.首次搜索位置初始值,结果有很多

 12.然后通过我说的“当穿装备才用变动的值搜索,当脱装备的时候要用未变动的值搜索”,关键点就是脱的时候要用未变

 13.通过不断地搜索改变,搜索出来的结果如下,发现就还有100多个结果,非常好!

14.这个时候我们拿到这些地址在XDBG观察这些值,结果在第二个地址就发现了我们需要的

15.查看穿装备的时候这个内存的变化

16.当我们脱下发现这个值不会变的

17.然后当再次穿装备,就会发现变动了

18.这个时候就需要再这个地址下写入断,看看能找到遍历吗

19.发现r15地址挂在一个UI控件相关对象上,这样就不对了,我们需要换一个思路,既然UI上挂这个r15地址,那么我们用CE搜索这个分配的内存地址,看看遍历应该也会挂着这个地址
20.注意分配的地址不是r15是写入的那个地址值

21.CE搜索到18个结果

22.一个一个观察,然后下断就可以找到遍历了,这里就比较简单了
23.找到一个结构体首地址,那么这个就是了

24.看一下内存,0x10结构体存的是装备栏中存装备的2个对象,我们之前搜索的就是第一个对象


25.下写入就可以来到遍历的地方了

23.好了!这一贴我们就讲完了,主要是介绍一种机制和一种CE搜索内存值的方法,可能不是最好的但是我们需要去了解它,这样才会以便不必只需
24.感谢支持迪大学院,希望多多点赞和关注,后续还有很多帖子不定时更新285530835

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/649085.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue中如何进行图片识别与物体检测

Vue中如何进行图片识别与物体检测 随着人工智能技术的发展,图像识别和物体检测已经成为了很多应用场景的必备功能。在Vue中如何使用百度AI或腾讯AI等云服务实现图片识别和物体检测呢?本文将为您介绍一些基本概念和示例代码,帮助您快速入门。…

强化学习PPO:Proximal Policy Optimization Algorithms解读

PPO算法是一类Policy Gradient强化学习方法,经典的Policy Gradient通过一个参数化决策模型来根据状态确定动作,其参数更新是通过下式进行的: 用于衡量决策模型的优劣目标,决策模型的优化目标为寻找最优决策,使得该决策…

电力辅助服务

电力辅助服务 1、电力辅助服务是什么2、电力辅助服务发展历程3、《电力辅助管理办法》主要修订内容4、电力辅助服务品种5、电力辅助服务市场规模6、国外电力辅助服务市场 1、电力辅助服务是什么 《电力辅助服务管理办法》中定义电力辅助服务是由火电、水电、核电、风电、光伏发…

Elastic 推出 Elastic AI 助手

作者:Mike Nichols Elastic 推出了 Elastic AI Assistant,这是一款由 ESRE 提供支持的开放式、生成式 AI 助手,旨在使网络安全民主化并支持各种技能水平的用户。 最近发布的 Elasticsearch Relevance Engine™ (ESRE™) 提供了用于创建高度相…

Spring Boot进阶(49):SpringBoot之集成WebSocket实现前后端通信 | 超级详细,建议收藏

1. 前言 在上一期,我对WebSocket进行了基础及理论知识普及学习,而这一期,我重点是要带着你们进行实战教学,手把手教学如何在springboot架构基础上集成WebSocket及实现前后端通讯功能。具有很好的学习价值,希望大家在学…

Python Selenium基本用法

Selenium 作为一款 Web 自动化测试框架,提供了诸多操作浏览器的方法,本节对其中的常用方法做详细介绍。 定位节点 Selenium 提供了 8 种定位单个节点的方法,如下所示: 定位节点方法 方法 说明 find_element_by_id() 通过 id 属性…

MacOS 高颜值的 数据库客户端工具 Tableplus 简单逆向分析

0x0 navicat 给公司发律师函了, 所以不能白嫖了.. 后来一直在找替代品, 但均感觉略有不足. dbeaver : java 开发的, 依赖 jdk , 而且BUG较多,也不流畅 mysqlworkbench : 官方出品, 功能强大. 但是用着不带劲 Sequel Ace : 开源免费, 但是只支持mysql,功能简单 最后试了下 Tab…

【手撕MyBatis源码】插件体系

文章目录 概述插件的使用插件代理机制自动分页插件拦截目标分页插件原理 概述 Mybatis作为一个应用广泛的优秀的ORM开源框架,这个框架具有强大的灵活性,在四大组件(Executor、StatementHandler、ParameterHandler、ResultSetHandler)处提供了简单易用的插…

​如何高效开发一个OA办公系统​?

如何才能高效开发一个OA办公系统?这篇教你使用零代码工具从0-1搭建一个OA办公系统,无需代码基础,只要你懂业务,只需3步即可搭建! 先来看看效果—— 系统模板>> https://www.jiandaoyun.com/ 整个系统包含物资管…

动态规划经典题型:最小路径和、所有路径

题目1:最小路径和 给定一个包含非负整数的 *m* x *n* 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。 说明:每次只能向下或者向右移动一步。 示例: 输入:grid [[1,3,1],[1…

计算机网络之链路层和局域网

六.链路层和局域网 6.1 链路层概述 6.1.1 链路层可能提供的服务 成帧、链路接入、可靠交付、差错检测和纠正 6.1.2 链路层在何处实现 下图是一个典型的主机体系结构,链路层的主体部分是在网络适配器实现的,部分链路层是在运行于主机CPU上的软件实现的…

融云 CTO 岑裕受邀出席亚马逊云科技「出海日」论坛

(点击购买《社交泛娱乐出海作战地图》) 6 月 9 日,亚马逊云科技主办的“潮向新世界”出海日活动在深圳举行,融云作为领军出海服务企业受邀出席。关注【融云全球互联网通信云】了解更多 在现场展位,融云的一站式全生态…

如何查看电脑是否安装了mysql

可以通过以下几种方式查看电脑是否安装了MySQL: 1. 在系统服务中查找MySQL服务 打开控制面板 → 管理工具 → 服务,在服务列表中查找“MySQL”服务。如果存在MySQL服务并且启动类型为“自动”或“手动”,则表示已安装MySQL。 2. 查找MySQL安装目录 一般MySQL的安装目录为:- Wi…

【Nexus】Linux安装Nexus

目录 一、安装包获取方式1、Nexus3.49版本的安装包2、Nexus3.53版本的安装包 二、下载安装包的两种方式(建议使用第一种安装方式)1、直接把下载好的安装包上传到服务器中2、通过wget安装Nexus压缩包①、可以使用以下命令进行安装Nexus的最新版本②、也可…

信号与系统小论文

信号与系统小论文 信号调制与解调模拟乘法器AD734信号调制信号解调 DFT和FFT 的运算复杂度比较DFT运算FFT运算复杂度比较 小论文有两个部分组成,第一个是用电路仿真实现信号的调制与解调,第二个是通过python将DFT和FFT运算的次数可视化。 信号调制与解调…

Mysql替换字段中的指定文本

前言 最近有个需求,不同的环境的ip和端口都不一样,所以就要修改表里面字段的值 但是手动修改比较麻烦而且很慢,所以在网上搜了下相关的方法。经过手动实践确实可行,下面分享给大家 准备fake数据 为了方便演示,准备…

pytorch实现图像分类器

pytorch实现图像分类器 一、定义LeNet网络模型1,卷积 Conv2d2,池化 MaxPool2d3,Tensor的展平:view()4,全连接 Linear5,代码:定义 LeNet 网络模型 二、训练并保存网络参数1,数据预处理…

mybatis-plus在实际开发中的应用

文章目录 前言一、实体类的注解二、Req查询条件三、Controller接口四、Service接口五、Service接口实现类六、Mapper接口七、枚举的使用总结 前言 最近的项目是使用mybatis-plus作为持久层框架,前面也记录过mybatis-plus的基本使用,此次记录一下本次项目…

行业报告|2022年智能制造人才发展报告:自动化、PLC、机器人等控制执行类研发岗需求增长快

原创 | 文 BFT机器人 近年来,我国智能制造应用规模和发展水平大幅跃升,制造业智能化发展成效明显,有力支撑工业经济的高质量发展。与此同时,我国在2022年首次出现人口负增长,该趋势下我国发展制造业的人口红利正逐步降…

BurpSuite全平台通用扩展

前言 昨天分享的关于springboot3集成ChatGPT实现AI聊天、生成图片,被CSDN以违规拒发了,找人工客服最后一肚子气,从上大学开始入住CSDN一直偏爱,确实不想放弃,似乎现在他已经不再是一个纯技术交流分享平台了&#xff0…