103.网游逆向分析与插件开发-网络通信封包解析-网络完成端口模型的流程

本文主要是介绍103.网游逆向分析与插件开发-网络通信封包解析-网络完成端口模型的流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内容参考于:易道云信息技术研究院VIP课

上一个内容:解读喊话道具数据包并且利用Net发送

通过之前的内容,把游戏的网络通信中关于发送数据的分析好了(任意涉及网络的应用程序里发送数据的数据包定位与分析都可以参考之前的内容),接下来要看它接收数据的处理,为什么要看接收数据?比如做一个聊天然后别人给你发送了一个消息,就要把别人说的话放到我们的聊天框里,这个时候有两种思路,第一种是处理内存,第二种就是通过网络来处理,这里就通过解读网络通信来实现。

这里就需要利用游戏(应用程序)接收数据的位置来看

首先要了解一下Recv 与 WSARecv,

Recv:

Recv是一个单线程接收数据的方式它与Send函数配合使用,Recv是单线程的,然后接收数据需要不断的循环,直到接收到数据,这个循环导致的效果就是应用程序卡死,所以一般高并发使用Recv需要使用多线程,开启一个线程,让这个线程不断的循环去Recv,然后把Recv到的数据放到一个队列里,然后由其它线程读取队列数据然后使用数据。

WSARecv:

使用WSARecv实际就是为了注册一个事件,调用了WSARecv并不会得到数据,想要获取数据需要通过回调函数得到,这个回调函数是通过消息机制出发,比如完成端口,往下看完成端口在下面解释了

完成端口一个流程:例子(iocp简单例子-带网络,基于iocp(完成端口)的线程安全队列-无网络纯iocp)

首先创建完成端口:CreateIoCompletionPort // 它是一个句柄

然后建立网络连接

然后投递完成端口:WSARecv // 注册一个事件接收消息

然后再启动一个线程:

  这个线程负责不停的查询完成端口的状态,也就是写一个循环:使用GetQueuedCompletionStatus

  这时如果完成端口有消息,就可以立马得到响应,然后通过重叠结构得到要做什么操作,GetQueuedCompletionStatus里WSASend、WSARecv、AcceptEx这三个操作都会得到(得到的不止这三个),然后就能得到 WSASend、WSARecv、AcceptEx 分别注册的消息,然后通过这注册的消息,去做对应的逻辑,也就是在 GetQueuedCompletionStatus 后面就可以找到 WSARecv这个操作,然后紧跟着数据解密(如果有加密的话),数据处理(就是数据解密完可以用了)

然后这次的WSARecv响应完成,如果还想下次被响应,那么还要再调用WSARecv注册一个消息,它跟Recv的逻辑是相反的,Recv是接收到数据然后处理,这个处理可能输多线程的,而完成端口是先接收数据(WSARecv)然后在 GetQueuedCompletionStatus 才真正得到数据然后处理。

然后现在有几条路,第一条是从GetQueuedCompletionStatus 里注册WSARecv的位置往前找,因为既然调用了WSARecv就说明处理完了数据,那么就往前看,第二条是通过 GetQueuedCompletionStatus往后找,然后找到跟WSARecv有关的过程,然后它们中间的过程就是我们要找的,这时就要找突破口,明文的数据与数据长度

然后网络的逆向如果不懂,那就说明正向的网络也不会写,这时就要去了解C++开发Windows服务器用的哪些API和Windows网络客户端怎么写用了哪些API,写一遍就可以懂了,因为你用的API是什么那些公司里也用什么,API是Windows的所以这是绝对不会变的,能用的函数就那些,大家也都用它们

如果不想采坑就看下面两个:去里面根据 GetQueuedCompletionStatus 关键字去找怎样使用

1.iocp简单例子-带网络

2.基于iocp(完成端口)的线程安全队列-无网络蠢iocp

1里现在只有服务端,客户端待补充,2里面没有用网络只用了iocp(可搜索 PostQueuedCompletionStatus关键字,查看纯iocp怎样使用)

这篇关于103.网游逆向分析与插件开发-网络通信封包解析-网络完成端口模型的流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/723271

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置