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

31.第二阶段x64游戏实战-封包-线程发包

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

本次游戏没法给

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

上一个内容:30.第二阶段x64游戏实战-认识网络数据包发送流程

代码跳转

ws2_32.send跳转send函数

ws2_32.sendto跳转sendto函数

ws2_32.WSASend跳转WSASend函数

注意跳转是区分大小写的,直接复制上面的就可以,其中ws2_32表示ws2_32模块,ws2_32.send表示ws2_32模块里的send函数

当前游戏用的是send函数发送的网络数据包,如下图在代码窗口按CTRL+G,然后输入 ws2_32.send然后点确定,它就跳转到了send函数里

send函数说明

搜索关键字

说明

第一个参数是套接字,套接字是网络连接的桥梁,就是我们的电脑和游戏公司的服务器只要有了套接字就可以互相访问了

第二个参数是发送的数据,也就是发送的网络数据包

第三个参数是发送的数据的长度

第四个参数是标志位,我们用不到,后面涉及到了会写说明(不要钻牛角尖,它不重要,不需要知道)

然后x64软件传参是用寄存器传参

rcx(第一个参数)套接字 rdx(第二个参数)数据包 r8(第三个参数)数据包长度 r9(第四个参数)标志位

这里要注意一件事,就是玩着玩着游戏,突然闪退了,然后不重新登录,过一段时间我们的角色就退出了,还有闪退之后重新登录的时候会提示角色以上线是否退出角色重新登录这种话语,然后多等一会重新登录就不会提示角色以上线这种话语,这个原因是,游戏会每个几秒会给服务器发送一个数据包用来告诉服务器角色还在线,当服务器一段时间收不到这个数据包就会给我角色下线,比如提示超时、网络连接错误等提示,写这么多想表达的是,我们在发送网络包函数上设置断点,会出现我们没有操作游戏(没有操作触发发送数据包的功能,比如打开设置窗口、背包、打开地图窗口)它也会在发送网络数据包的函数上断下来,所以要有一个感觉,就是要确保发送网络数据包的函数是我们触发的,比如发送聊天数据、移动、释放技能等,为了避免找半天找的不对,这个感觉很重要。

开始断点调试,设置断点

然后这个游戏它有一个防御,有一个概念,Windows系统打开多个窗口,它只会有一个活动窗口,活动窗口的意思现在打开了a窗口和b窗口,鼠标左键单击a窗口,活动窗口就是a窗口,鼠标左键单击b窗口,活动窗口就是b窗口,鼠标左键单机窗口时会有一个激活(Windows中叫得到焦点)操作,只要鼠标左键单击了窗口它就会有激活这个动作,没办法关,所有窗口都有,这个游戏当窗口激活时会发送一个网络数据包(这种称为心跳),来扰乱我们,所以接下来就是想办法跳过激活窗口发送的网络数据包。

下面开始,上方写了send函数的介绍,rdx是第二个参数,第二个参数是发送的网络数据包,如下图选择转到内存窗口,r8是第三个参数,第三个参数是数据包的长度0xE

然后它的数据是80555,然后按F9让代码运行起来,然后再次点击游戏窗口触发断点,它还是80555,并且数据包的长度也没有变化一直是0xE,也就是说激活窗口发送的数据包是固定的,是固定的就可以使用条件断点了

鼠标右击选择设置条件断点

然后输入r8!=0xE,设置完之后,激活窗口的数据包就不会断下来的,再自动断下来的就是游戏内部的数据包了,比如心跳

如下图是通过发送聊天数据触发的断点

然后点击调用堆栈,下图是发送聊天数据的调用堆栈

下图是通过走路发送的数据包

它的堆栈,可以发现一个事情,走路的调用堆栈和发送聊天数据的调用堆栈是一模一样的,这就很奇怪两个不同的功能一个是发送聊天数据,一个是走路,调用的函数却一模一样

一模一样的原因是,这个游戏发送数据包操作用最少三个线程支持,如下图加密完的数据包,写到一个内存空间里就完事了,然后发送数据包也就是send函数,它会不断的读取存放数据包的内存空间,里面只要有数据它就发送网络数据包,然后上面的断点是在send函数,所以移动和发送聊天数据调用的函数(调用堆栈)一模一样,这种情况就被称为线程发包

然后怎么追加密数据包的位置?发送网络数据包的内存地址是不变的,所以对这个内存地址设置硬件写入断点,就可以找到加密的位置了,这里注意硬件断点,不能设置条件,所以硬件断点会是激活窗口触发的(这个没事,下一节就会写怎么办)

然后就来到了下图位置

然后如下图,可以看到它写入的是word是2字节,所以这里多半是复制数据的函数(就是把存放数据包的内存里的数据写到发送数据包函数里或者说线程里)

然后删除断点

然后按CTRL+F9,再按F8,可以看到确实是在复制函数里memmove

memmove函数说明,将一个缓冲区移动到另一个缓冲区,这意思就是剪切操作(复制完删除)


img

相关文章:

31.第二阶段x64游戏实战-封包-线程发包

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 上一个内容:30.第二阶段x64游戏实战-认识网络数据包发送流程 代码跳转 ws2_32.send跳转sen…...

Unity数字人开发笔记

开源工程地址:https://github.com/zhangliwei7758/unity-AI-Chat-Toolkit 先致敬zhangliwei7758,开放这个源码 一、建立工程 建立Unity工程(UnityAiChat)拖入Unity-AI-Chat-Toolkit.unitypackage打开chatSample工程,可…...

嵌入式开发--STM32G431无法正常运行程序,BOOT0与CAN冲突

故障现象 今天开发STM32G431时遇到一个问题,板子打样回来后,焊接完成,可以烧程序,可以读FLASH,却死活不能运行,也不能进仿真调试。 故障定位 经过排查,发现将隔离芯片π121M31拆除&#xff0…...

每天掌握一个Linux命令 - sqlite3

Linux 命令工具 sqlite3 使用指南 一、工具概述 sqlite3 是 SQLite 数据库的命令行工具,用于在 Linux 系统中直接操作 SQLite 数据库(轻量级、无服务器、嵌入式关系型数据库)。 核心特点: 无需安装数据库服务,直接通…...

程序环境与预处理

一、程序的翻译环境和执行环境 翻译环境:将源代码转化为可执行的机器指令 执行环境:执行代码 1、翻译环境 流程: 二、运行环境 程序执行过程: 三、预编译阶段 1、预定义符号 __FILE__ //进行编译的原文件名 __LINE__ //文…...

RT Thread Nano V4.1.1 rtconfig.h 注释 Configuration Wizard 格式

rtcomfig.h 以下是对 [rtconfig.h](file://c:\Users\admin\Downloads\rtthread-nano-master\rt-thread\bsp\stm32f407-msh\RT-Thread\rtconfig.h) 文件中每一个配置项的详细注释说明: 基本配置(Basic Configuration) [RT_THREAD_PRIORITY_MAX](file://c:\Users\admin\Downl…...

《Java 单例模式:从类加载机制到高并发设计的深度技术剖析》

【作者简介】“琢磨先生”--资深系统架构师、985高校计算机硕士,长期从事大中型软件开发和技术研究,每天分享Java硬核知识和主流工程技术,欢迎点赞收藏! 一、单例模式的核心概念与设计目标 在软件开发中,我们经常会遇…...

JSONP跨域原理全解析

JSONP&#xff08;JSON with Padding&#xff09;是一种绕过浏览器同源策略限制、实现跨域数据请求的“hack”式方案。其核心原理和流程如下&#xff1a; 同源策略限制 浏览器为了安全&#xff0c;只允许页面从与当前页面相同协议、域名、端口的服务器加载数据。而 <script&…...

【MySQL】第11节|MySQL 8.0 主从复制原理分析与实战(一)

一、MySQL主从复制基础 1. 核心概念 定义&#xff1a; MySQL主从复制是将主库&#xff08;Source/Master&#xff09;的数据变更同步到一个或多个从库&#xff08;Replica/Slave&#xff09;的机制&#xff0c;默认采用异步复制&#xff0c;支持全库、指定库或表的同步。 角…...

全志F1c200开发笔记——移植根文件系统

1.下载buildroot Index of /downloads/ 使用2018.02.11版本 直链下载 https://buildroot.org/downloads/buildroot-2018.02.11.tar.gz 2.配置 进入buildroot压缩包目录下&#xff0c;使用命令解压并进入工作目录 tar -xf buildroot-2018.02.11.tar.gz cd buildroot-2018.…...

[yolov11改进系列]基于yolov11引入自注意力与卷积混合模块ACmix提高FPS+检测效率python源码+训练源码

[ACmix的框架原理] 1.1 ACMix的基本原理 ACmix是一种混合模型&#xff0c;结合了自注意力机制和卷积运算的优势。它的核心思想是&#xff0c;传统卷积操作和自注意力模块的大部分计算都可以通过1x1的卷积来实现。ACmix首先使用1x1卷积对输入特征图进行投影&#xff0c;生成一组…...

Java NIO编程:构建高性能网络应用

1.Java NIO 核心概念与架构 1. 传统 BIO 与 NIO 的对比 特性 BIO (Blocking I/O) NIO (Non-blocking I/O) I/O 模型 阻塞 非阻塞 / 异步 线程模式 每个连接一个线程 单线程管理多个连接 数据处理单位 字节流 / 字符流 缓冲区 (Buffer) 核心组件 Socket, ServerSoc…...

如何实现高性能超低延迟的RTSP或RTMP播放器

随着直播行业的快速发展&#xff0c;RTSP和RTMP协议成为了广泛使用的流媒体传输协议&#xff0c;尤其是在实时视频直播领域&#xff0c;如何构建一个高性能超低延迟的直播播放器&#xff0c;已经成为了决定直播平台成功与否的关键因素之一。作为音视频直播SDK技术老兵&#xff…...

每天掌握一个Linux命令 - sar

Linux 系统监控工具 sar 使用指南 一、工具概述 sar&#xff08;System Activity Reporter&#xff09; 是 Linux 下功能强大的系统活动报告工具&#xff0c;属于 sysstat 软件包的核心组件。它通过采集系统资源&#xff08;CPU、内存、磁盘、网络、进程等&#xff09;的使用…...

RabbitMQ 集群与高可用方案设计(三)

五、高可用方案设计与实现 &#xff08;一&#xff09;负载均衡与代理 1. HAProxy 配置 HAProxy 是一款广泛应用的开源负载均衡器和代理服务器&#xff0c;它能够实现对 RabbitMQ 集群节点的负载均衡和健康检查&#xff0c;有效提高系统的可用性和性能。以下是使用 HAProxy …...

Linux的读写屏障

在 Linux 中&#xff0c;读写屏障&#xff08;Read-Write Barriers&#xff0c;简称 RWB&#xff09;是对内存访问顺序的一种控制机制&#xff0c;用来保证在多核处理器环境下&#xff0c;内存访问的正确顺序&#xff0c;避免因乱序执行导致的数据一致性问题。它是操作系统内核…...

Vue中的 VueComponent

VueComponent 组件的本质 Vue 组件是一个可复用的 Vue 实例。每个组件本质上就是通过 Vue.extend() 创建的构造函数&#xff0c;或者在 Vue 3 中是由函数式 API&#xff08;Composition API&#xff09;创建的。 // Vue 2 const MyComponent Vue.extend({template: <div…...

C语言数据结构-单向链表

头文件&#xff1a;link.h #ifndef __LINK_H__ #define __LINK_H__ #include <stdio.h> #include <stdlib.h> typedef int DataType; /*节点数据类型*/ typedef struct node { DataType data; //数据域 struct node *pNext; //指…...

小样本分类新突破:QPT技术详解

问题导向式提示调优(QPT) 这篇论文主要讲了一个针对小样本(数据量少)文本分类问题的新方法,叫问题导向式提示调优(QPT)。 核心思路是让预训练语言模型(比如BERT的升级版RoBERTa)在少量标注数据下,通过设计特定的“提问式模板”和“标签词扩展技术”来提升分类效果。…...

Excel常用公式全解析(1):从基础计算到高级应用

Excel常用公式全解析&#xff1a;从基础计算到高级应用 目录 Excel常用公式全解析&#xff1a;从基础计算到高级应用[toc](目录)一、基础计算类&#xff1a;数据运算的基石1. 求和公式&#xff08;SUM&#xff09;2. 平均值公式&#xff08;AVERAGE&#xff09;3. 最值与计数公…...

C++ STL 容器:List 深度解析与实践指南

一、List 容器概述 1.1底层结构与特性 数据结构&#xff1a;双向循环链表&#xff08;带哨兵位头结点&#xff09;&#xff0c;每个节点包含前驱指针、后继指针和数据域。核心优势&#xff1a; 高效插入 / 删除&#xff1a;任意位置操作时间复杂度为 O (1)&#xff0c;无需移…...

每天掌握一个Linux命令 - ab(Apache Benchmark)

Linux 命令工具 ab 使用指南 一、工具概述 ab&#xff08;Apache Benchmark&#xff09; 是 Apache 官方提供的开源压力测试工具&#xff0c;用于衡量 Web 服务器的性能。它通过模拟多并发请求&#xff0c;测试服务器在高负载下的响应速度、吞吐量和稳定性&#xff0c;常用于…...

与 PyCharm 官方沟通解决开发环境问题记录(进展:官方已推出2个新的修复版本)

​​​​​​主题&#xff1a;有关 PyCharm 中终端和环境激活问题的反馈&#xff1a;PY-81233 前言 目前进展&#xff1a; 官方已有2个修复版本推出测试。 更新方法&#xff1a; 使用JetBrains Toolbox App&#xff0c;如下图所示&#xff0c;从“其他版本”进入查看更新。…...

Python的分布式网络爬虫系统实现

1. 系统架构概述 一个典型的分布式网络爬虫系统通常包含以下几个核心组件&#xff1a; 1.主节点&#xff08;Master Node&#xff09;&#xff1a; 任务调度&#xff1a;负责将抓取任务分配给各个工作节点。URL 管理&#xff1a;维护待抓取的 URL 队列和已抓取的 URL 集合&a…...

Vue快速上手(业务、技术、报错)

Vue 技术业务报错 技术 业务 Vueelement-ui&#xff0c;实现表格渲染缩略图&#xff0c;鼠标悬浮缩略图放大&#xff0c;点击缩略图播放视频&#xff08;一&#xff09; 报错 vue修改配置文件.env.development不生效 vue前端downloadFile报错&#xff1a;Error parsing HT…...

taro + vue3 实现小程序sse长连接实时对话

前言 taro.request是可以实现sse长连接的&#xff0c;但是呢其中有俩大坑&#xff0c;找了许多资料也没解决&#xff0c;后续解决办法也与后端商量改用WebSocket来实现。 代码实现 SSEManager.js: import { getAccessToken } from "../xx/xx"; import { TextDecode…...

使用MATLAB求解微分方程:从基础到实践

使用MATLAB求解微分方程&#xff1a;从基础到实践 微分方程是描述自然界和工程领域中许多现象的重要数学工具。MATLAB提供了强大的工具来求解各种类型的微分方程。本文将介绍如何使用MATLAB求解常微分方程(ODE)。 1. 基本ODE求解器 MATLAB提供了多种ODE求解器&#xff0c;最…...

基于MATLAB的大规模MIMO信道仿真

1. 系统模型与参数设置 以下是一个单小区大规模MIMO系统的参数配置示例&#xff0c;适用于多发多收和单发单收场景。 % 参数配置 params.N_cell 1; % 小区数量&#xff08;单小区仿真&#xff09; params.cell_radius 500; % 小区半径&#xff08;米&#xff09…...

如何在 Windows 和 Mac 上擦拭和清洁希捷外置硬盘

希捷外置硬盘广泛用于存储目的&#xff0c;但有时您可能出于多种目的需要擦除或清洁希捷外置硬盘&#xff0c;例如转售、重复使用、捐赠等。为了释放硬盘上的存储空间或确保没有人可以从硬盘中恢复您的信息&#xff0c;擦除硬盘是必要的步骤。无论您使用的是 Windows 还是 Mac&…...

Vue 3.0 中状态管理Vuex 与 Pinia 的区别

在 Vue.js 应用开发中&#xff0c;状态管理是构建复杂应用的关键环节。随着 Vue 3 的普及和 Composition API 的引入&#xff0c;开发者面临着状态管理库的选择问题&#xff1a;是继续使用经典的 Vuex&#xff0c;还是转向新兴的 Pinia&#xff1f;本文将从设计理念、API 设计、…...