10.第二阶段x86游戏实战2-反编译自己的程序加深堆栈的理解
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动!
本次游戏没法给
内容参考于:微尘网络安全
工具下载:
链接:https://pan.baidu.com/s/1rEEJnt85npn7N38Ai0_F2Q?pwd=6tw3
提取码:6tw3
复制这段内容后打开百度网盘手机App,操作更方便哦
上一个内容:9.第二阶段x86游戏实战2-初识易语言
上一个内容里使用易语言写了一个Windows窗口程序,本次就来逆向这个程序,看看它的反汇编代码和栈是怎么一个情况。
开始之前要回顾一个东西,在 6.第二阶段x86游戏实战2-理解程序流程 里写过一个流程 寻路到有怪物的位置-》选择怪物-》打怪物-》捡怪物的掉落物 这个流程,还把 寻路到有怪物的位置 拆分成了 上坐骑 -》打开地图 -》寻路 -》确认到达 -》下坐骑 这样的一个流程,然后现在再给寻路拆分一下,寻路可以拆分成 获取鼠标单击的坐标-》检测当前位置,然后OD里的CTRL+F9快捷键可以返回到当前函数的上一层(调用当前函数的位置),然后如果在获取鼠标单击的坐标这里打断点,然后按CTRL + F9,它会返回到 寻路 里,然后在寻路里按CTRL+F9它会回到 寻路到有怪物的位置 里,这句话要记住(记不住起码要有印象,知道有这么个事),逆向的过程就是围绕着这句话进行的。
然后开始
首先打开之前用易语言写的窗口程序
![]()
然后使用OD附加,如下图箭头,鼠标左键在拖拽上按住,然后拖到易语言写的窗口里就可以附加了
![]()
然后CTRL+G,然后输入MessageBoxA,然后点OK,第一个打开OD需要重复操作多次(直到没反应了为止)
![]()
然后点了OK之后就会来到下图红框位置,这里的内存地址是0x7629B160,这个内存地址是会变的,跟下图不一样是正常的
![]()
然后这里需要说明一下 MessageBoxA 是Windows系统的函数所以可以使用CTRL+G输入MessageBoxA的方式跳转,正常CTRL+G是通过内存地址跳转的。
然后鼠标左键双击下图红框位置
![]()
双玩之后的效果,内存地址会变成红色背景,这说明在这个位置打断点了,当程序运行到这时就会卡主
![]()
然后来到易语言写的程序里,点击下图红框里的按钮
![]()
下图红框是效果,执行了下图蓝框的代码就会弹出红框里的弹框
![]()
然后点击弹框里的确定
![]()
然后来到OD,会发现触发断点了,程序写卡主了
![]()
然后双击下图红框位置
![]()
双击完取消断点
![]()
然后就开始围绕刚开始写的那句话了,为了避免晕这里详细说明,下图是易语言写的代码,然后下图红框里的代码执行完是一个弹框,它实际就是调用的MessageBoxA函数,然后上方在MessageBoxA函数里打了断点,然后在MessageBoxA函数里按CTRL+F9就会来到 信息框 (“信息框”, 0, , ) 这个函数里面,注意按了CTRL + F9之后是在 信息框 (“信息框”, 0, , ) 里面不是下图红框位置
![]()
然后按CTRL+F9,来到 信息框 (“信息框”, 0, , ) 里面
![]()
然后在按CTRL+F9
![]()
上图的代码,是下图红框里面的内容,下图红框是一个子程序(函数)名字叫dddd,也就是说上图的代码是dddd函数的汇编代码
![]()
然后dddd函数实在下图红框位置调用的
![]()
然后下图的代码是 我可是按钮 点击之后执行的代码
![]()
然后再按CTRL+F9
![]()
上图红框里的代码,是下图红框代码的反汇编代码
![]()
这里我为什么会知道?如下图红框 64是一个十六进制数,这里不能读六十四,要读六四,然后14也是一个十六进制数,OD显示的数字一般都是十六进制数,然后64的十进制是100,它对应下图蓝框里的100,14的十进制数是20它对应下图蓝框里的20,通过这样的特征来确认的,后面看多了也就能掌握了
![]()
然后开始正文,堆栈
然后先按一下F9让程序运行起来,然后在下图红框位置打断点
![]()
然后来到易语言的窗口点击 我可是按钮,然后断点住
![]()
然后看下图红框,esp是栈顶(栈里的第一个数据)ebp是栈底(当前栈里最后一个数据)
![]()
然后双击下图红框位置
![]()
双击完它会出现一个偏移方便观察
![]()
然后取消断点,按F7执行call 0x401040,也就是执行dddd函数,如下图按了F7之后进入dddd函数,然后下图红框位置可以看到栈里有添加了一个数据
![]()
call这个汇编代码会跳转到指定位置并且把下一行代码的地址放到栈里,如下图红框
![]()
然后开始观察栈
然后按F8,它执行了push ebp,这意思是把原本的栈底保存起来
![]()
然后再按F8,执行了mov ebp, esp,这意思是切换到新的栈(栈物理上是一大块内存地址,在使用上是一块一块的用,通过下图的代码可以很明显看出来)里
![]()
然后再按F8,执行sub esp,0C,这意思是开辟局部变量的内存,注意现在栈里-14、-10、-C位置的数据是乱的
![]()
sub esp,0C的目的就是为了,下图红框里的三个变量
![]()
然后回到OD继续按F8,如下图红框它给局部变量进行了初始化为0,也就是说易语言中的局部变量如果不赋值它默认是0
![]()
然后继续按F8
![]()
上图里它执行了mov dword ptr [ebp-4], 3E8,也就是下图红框的代码,3E8的十进制是1000
![]()
![]()
然后继续按F8
![]()
上图里它执行了 mov eax, dword ptr [ebp+C],ebp+c是参数,也就是下图红框的代码
![]()
它是在下图红框位置call 00401040函数(dddd函数)之前进入栈里的
![]()
然后继续按F8
![]()
上图里执行了 mov dword ptr [ebp-8], eax这个代码,也就是下图红框里的代码
![]()
然后下图红框的两行代码
![]()
是下图红框里的代码,与 _接收攻击 = 攻击 一样这里执行F8跳过了
![]()
然后下图红框的代码是易语言生成的代码不是我们写的,直接F8跳过就行了
![]()
call 00401038最终会通过下图红框位置跳转到下图蓝框位置
![]()
然后下图红框位置的代码是 准备执行 信息框 (“信息框”, 0, , ) 这个代码
![]()
执行在下图红框位置打断点,按F9然后点击弹框的 确定 按钮跳过就行了
![]()
然后点击完确定来到下图红框位置
![]()
然后按F8,执行 add esp, 34 意思是函数运行过程中会出现很多局部变量 add esp, 34 就是为了清理局部变量的,也就是还原栈
![]()
然后再按F8,执行 mov esp, ebp意思是还原成调用dddd函数之前栈的栈顶(第一个数据位置)
![]()
然后再按F8,执行 pop ebp意思是还原调用dddd函数时的栈底
![]()
然后在按F8,执行retn 8,retn是把栈里第一个数据当成代码的内存地址并且跳转到这个地址上,并且esp+8,8的意思是当前函数(dddd函数)有两个参数(一个参数是4字节两个是8字节,这里的8就是8字节的意思),就是一个平栈(还原成进入dddd函数之前的栈),如下图
![]()
上图可以看出执行了retn 8,下图可以看出retn 8把下图红框位置两次push到栈里的数据给清理了(esp+8)
![]()

相关文章:
10.第二阶段x86游戏实战2-反编译自己的程序加深堆栈的理解
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 工具下载: 链接:https://pan.baidu.com/s/1rEEJnt85npn7N38Ai0_F2Q?pwd6tw3 提…...
ARM总复习
1.计算机的组成 输入设备 输出设备 存储设备 运算器 控制器、总线 2.指令和指令集 2.1 机器指令 机器指令又叫机器码,在运算器内部存在各种运算电路,当处理器从内存中获取一条机器指令,就可以按照指令让运算器内部的指定的运算电路进行运…...
使用ENVI之大气校正(下)
再根据遥感影像的拍摄时间将Flight ate与Flight Time GMT (H:M:SS)填写,如要查询按如下方法 这里按照表中的内容修改 根据影像范围的经纬度与拍摄时间更改Atmospheric Model,更改完成后点击Multispectral Settings...在跳出的界面中选择GUI再点击Default…...
C++(学习)2024.9.18
目录 C基础介绍 C特点 面向对象的三大特征 面向对象与面向过程的区别 C拓展的非面向对象的功能 引用 引用的性质 引用的参数 指针和引用的区别 赋值 键盘输入 string字符串类 遍历方式 字符串与数字转换 函数 内联函数 函数重载overload 哑元函数 面向对象基…...
认知小文2《成功之路:习惯、学习与实践》
内容摘要: 在这个充满机遇的时代,成功不再是偶然,而是可以通过培养良好习惯、持续学习和实践来实现的目标。 一、肌肉记忆:技能的基石 成功往往需要像运动员一样,通过日复一日的练习来形成肌肉记忆。无论是健身…...
【数据仓库】数据仓库层次化设计
一、基本概念 **1. RDS(RAW DATA STORES,原始数据存储)** RDS作为原始数据存储层,用于存储来自各种源头的未经处理的数据。这些数据可能来自企业内部的业务系统、外部数据源或各种传感器等。RDS确保原始数据的完整性和可访问性&…...
【DAY20240918】03教你轻松配置 Git 远程仓库并高效推送代码!
文章目录 前言 git diff一、远程仓库?1、在 Gitee 上新建仓库:2、Git 全局设置:3、添加远程仓库:4、推送本地代码到远程仓库:5、输入用户名和密码:6、后续推送: 二、全情回顾三、参考 前言 git …...
从IPC摄像机读取视频帧解码并转化为YUV数据到转化为Bitmap
前言 本文主要介绍根据IPC的RTSP视频流地址,连接摄像机,并持续读取相机视频流,进一步进行播放实时画面,或者处理视频帧,将每一帧数据转化为安卓相机同格式数据,并保存为bitmap。 示例 val rtspClientListener = object: RtspClient.RtspClientListener {override fun …...
LeetCode 面试经典 150 题回顾
目录 一、数组 / 字符串 1.合并两个有序数组 (简单) 2.移除元素 (简单) 3.删除有序数组中的重复项 (简单) 4.删除有序数组中的重复项 II(中等) 5.多数元素(简单&am…...
【网络安全的神秘世界】渗透测试基础
🌝博客主页:泥菩萨 💖专栏:Linux探索之旅 | 网络安全的神秘世界 | 专接本 | 每天学会一个渗透测试工具 渗透测试基础 基于功能去进行漏洞挖掘 1、编辑器漏洞 1.1 编辑器漏洞介绍 一般企业搭建网站可能采用了通用模板ÿ…...
【重学 MySQL】二十九、函数的理解
【重学 MySQL】二十九、函数的理解 什么是函数不同 DBMS 函数的差异函数名称和参数功能实现数据类型支持性能和优化兼容性和可移植性 MySQL 的内置函数及分类单行函数多行函数(聚合函数)使用注意事项 什么是函数 函数(Function)在…...
MySQL5.7主从复制搭建-gtid方式
环境准备 1、主机名和和IP地址如下 10.0.0.51 db01.ljbb.com 10.0.0.52 db02.ljbb.com 10.0.0.53 db03.ljbb.com2、配置文件 db01 [mysqld] usermysql basedir/app/mysql datadir/data/mysql/data socket/tmp/mysql.sock server_id51 port3306 secure-file-priv/tmp autoco…...
golang学习笔记22——golang微服务中数据竞争问题及解决方案
推荐学习文档 golang应用级os框架,欢迎stargolang应用级os框架使用案例,欢迎star案例:基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总想学习更多golang知识,这里有免费的golang学习笔…...
yolo训练出现Could not load library libcudnn_cnn_train.so.8问题及解决方法
问题场景: 训练yolov5或者yolov8时候会报错: Could not load library libcudnn_cnn_train.so.8. Error: /usr/local/cuda-12.1/lib64/libcudnn_cnn_train.so.8: uined symbol: _ZN5cudnn3cnn34layerNormFwd_execute_internal_implERKNS_7backend11Vari…...
携手科大讯飞丨云衔科技为企业提供全栈AI技术解决方案
作为智能时代的核心驱动力,人工智能不仅重塑了传统行业的面貌,更开辟了全新的经济增长点。科大讯飞以其深厚的技术底蕴和创新能力,持续引领着人工智能领域的发展潮流。云衔科技作为科大讯飞开放平台的AI技术产品线合作伙伴代理商,…...
57页PPT | 智慧文旅整体建设解决方案
主要介绍了智慧文旅的建设背景、需求分析、解决方案、应用系统功能需求、客户价值、企业价值、建设理念、建设思路、总体架构、安全管理体系、融媒体综合服务平台、大数据分析平台、智慧文旅云平台、智慧管理、智慧营销、智慧服务等方面的内容。 背景及需求分析 方案架构及理念…...
线性代数之QR分解和SVD分解
文章目录 1.QR分解Schmidt正交化Householder变换QR分解的应用 2. 求矩阵特征值、特征向量的基本方法3.SVD分解SVD分解的应用 参考文献 1.QR分解 矩阵的正交分解又称为QR分解,是将矩阵分解为一个正交矩阵Q和一个上三角矩阵R的乘积的形式。 任意实数方阵A,…...
在虚拟机安装mysql数据库
一、安装步骤(下载包-传输软件包-安装包-启用仓库-使用yum安装服务器) 1、要在mysql官网下载yum仓库包 2、下载好rpm包后,将其通过xftp传输到root目录下 3、使用sudo yum install yum的仓库名(sudo yum install mysql-community-…...
详解QT插件机制
Qt插件机制允许将功能模块化为独立的插件,从而在运行时动态加载和卸载这些模块。这种机制对于扩展应用程序、插件架构和动态功能添加非常有用 插件机制 插件的基本概念 插件: 在Qt中,插件是实现特定接口的动态库(DLL或so文件),这些接口由Qt插件框架定义。插件可以被应用程序…...
【Hot100】LeetCode—32. 最长有效括号
目录 1- 思路题目识别动态规划 2- 实现⭐32. 最长有效括号——题解思路 3- ACM 实现 原题链接:32. 最长有效括号 1- 思路 题目识别 识别1 :给定一个字符串 s ,求解 s 中的最长有效括号 动态规划 动态规划五部曲 递推公式难如果遇到了 s.…...
利用最小二乘法找圆心和半径
#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …...
业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
java_网络服务相关_gateway_nacos_feign区别联系
1. spring-cloud-starter-gateway 作用:作为微服务架构的网关,统一入口,处理所有外部请求。 核心能力: 路由转发(基于路径、服务名等)过滤器(鉴权、限流、日志、Header 处理)支持负…...
以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:
一、属性动画概述NETX 作用:实现组件通用属性的渐变过渡效果,提升用户体验。支持属性:width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项: 布局类属性(如宽高)变化时&#…...
Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例
使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...
【SpringBoot】100、SpringBoot中使用自定义注解+AOP实现参数自动解密
在实际项目中,用户注册、登录、修改密码等操作,都涉及到参数传输安全问题。所以我们需要在前端对账户、密码等敏感信息加密传输,在后端接收到数据后能自动解密。 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId...
MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
【项目实战】通过多模态+LangGraph实现PPT生成助手
PPT自动生成系统 基于LangGraph的PPT自动生成系统,可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析:自动解析Markdown文档结构PPT模板分析:分析PPT模板的布局和风格智能布局决策:匹配内容与合适的PPT布局自动…...
Java面试专项一-准备篇
一、企业简历筛选规则 一般企业的简历筛选流程:首先由HR先筛选一部分简历后,在将简历给到对应的项目负责人后再进行下一步的操作。 HR如何筛选简历 例如:Boss直聘(招聘方平台) 直接按照条件进行筛选 例如:…...
初探Service服务发现机制
1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能:服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源…...
