当前位置: 首页 > news >正文

12.第二阶段x64游戏实战-远程调试

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动!

本次游戏没法给

内容参考于:微尘网络安全

上一个内容:11.第二阶段x64游戏实战-框架代码细节优化

本次写的内容是关于调试、排错相关的,在写代码的过程中肯定会遇到问题,不可能会一帆风顺

比如说注入我们写的dll之后游戏就会崩溃或者点击按钮之后会崩溃,这要怎么解决问题?怎么找出问题在哪,比如有人写了代码会让游戏崩溃,然后跑过来跟我说游戏崩溃,我根本不知道你说的是什么,正确的是找到问题,比如这行代码怎么怎么报错了怎么怎么不行,就要把问题的细节描述出来

首先是注入就崩溃,这是什么情况?

关于注入就崩溃这个问题,首先要搞清楚代码执行的流程,就是说我们的dll一注入进去会发生什么情况,从哪里开始执行,如下图红框MFCdll一注入进去会从以项目名字命名的.cpp文件开始

从InitInstance函数开始执行

所以一注入就崩溃可以写打印日志的代码,如下图红框的代码是用来打印日志

然后如下图红框就在InitInstance函数中调用LogA函数,打印日志,这样可以看到执行到哪一行,导致的崩溃,如果打印了1111没打印2222就说明73行代码报错了,这样就定位到错误的代码了,就是看它执行到那了该有的日志有没有打印出来

查看日志的方式是通过Dbgview这个软件,打开之后点击下图红框位置,包含写的*说明所有日志都打印,包含它还可以AAA*这样就只打印内容以AAA开头的数据,排除写的1;2;3说明只要日志的内容包含1或2或3就不显示

现在的日志代码正常执行它会打印1111、2222、3333、4444

注入打印的内容,为什么没打印4444?因为 PMainDialog->DoModal(); 这个代码是一个模态窗口,代码会在它这一行卡主后面不会执行,只有把窗口关闭了才会打印4444

关闭窗口打印4444,通过这些步骤的打印就可以清楚的知道代码执行的流程,也就能知道注入就崩溃是哪一行代码引起的

注入不崩溃点击按钮这种的崩溃怎么办?

也是跟上方注入崩溃一样,找到按钮点击之后执行的函数,把每一行都加上LogA,看看执行了哪一行代码导致了崩溃

如果不想用上面的方式可以使用 Visual Studio 2022 提供的附加,如下图点击附加到进程

然后如下图搜索进程名,找到想要附加的进程

鼠标左键单机进程,然后点附加

附加之后的样子

然后在入口位置设置断点,如下图红框

然后使用注入器注入我们的dll文件,然后就可以触发我们设置的断点了

它是可以直接看得到每个变量内存的数据的,可以很方便的看崩溃的原因 ,比较好用,但是有些有检测的软件没法使用,到时候还是要用LogA的方式


img

http://www.dtcms.com/a/137753.html

相关文章:

  • 美团一面总结
  • list的一些常用接口
  • 流量统计实例
  • 域AD渗透手法【密码喷洒技术】
  • 【JavaScript】二十三、M端事件 + 轮播图Swiper插件
  • USB(TYPE-C)转串口(TTL)模块设计讲解
  • C++之 动态数组
  • 河南普瑞维升企业案例:日事清SOP流程与目标模块实现客户自主简报功能落地
  • 智能语音处理+1.5使用PocketSphinxshinx实现语音转文本(100%教会)
  • Pinpoint - 大型分布式系统的 APM(应用性能管理)工具
  • 强化学习的数学原理(五) MonteCarlo learning
  • MoogDB数据库日常维护技巧与常见问题解析
  • 未能安装包“Microsoft.VisualStudio.XXXXX
  • 3D语义地图中的全局路径规划!iPPD:基于3D语义地图的指令引导路径规划视觉语言导航
  • BR_输出功率(RF/TRM/CA/BV-01-C [Output Power])
  • 从零开始实现 MobileViT 注意力机制——轻量级Transformer Vision Model 的新思路
  • PyTorch框架学习01
  • 低盐、低蛋白、低钾饮食的肾脏保护机制(肾和计算机语言)
  • 第七章:7.6 写一个函数,将两个字符串连接
  • ThinkPHP框架接入Stripe支付
  • 【贪心】C++ 活动安排问题
  • 三角形分类程序黑盒实验(三)(包含完整源码)
  • 深入解析C++中的队列(queue)容器:原理、应用与最佳实践
  • 16613/16614/16615系列噪声源
  • 线上创业协会小程序源码介绍
  • 52常用控件_QCheckBox的使用
  • Vue.js:现代前端开发的轻量级框架
  • 蓝桥杯 6. k倍区间
  • 来个去照片背景的GUI程序
  • git 根据http url设置账号密码