游戏外挂怎么做?

article/2025/9/24 6:10:06

文章目录

  • 1.什么是游戏外挂
  • 2.外挂的分类及实现原理
    • 2.1 辅助类外挂
    • 2.2 专用插件类外挂
    • 2.3 通用工具
    • 2.4 内存修改器
    • 2.5 变速器
    • 2.6 按键精灵
    • 2.7 模拟器
    • 2.8 破解版

转载自:Anti-Cheat Expert 游戏安全专家
干货!什么是游戏外挂,外挂的种类及实现原理

很多粉丝都知道,我之前写过几个游戏AI开挂的文章,这些文章主要是利用游戏内数据训练游戏AI预测敌方对手的状态,这样就可以做到让AI在即时战斗中学会执行下一步的操作。

https://mp.weixin.qq.com/s/_SzK8FTITuZz8uW_UH__GA

但是上面的方法往往需要获取大量的游戏数据喂给模型进行训练,开发这样的游戏AI外挂具有一定的成本。为了让读者们更加了解日常的外挂是怎么做的,因此带来了这篇“游戏外挂”文章进行科普。

1.什么是游戏外挂

外挂,原指一切用来破坏游戏程序正常游戏数据和逻辑的工具或破解版。比如可以修改游戏内存数据的修改器,又比如可以修改网络数据包的抓包工具。这类外挂或多或少会影响游戏的内存数据、文件数据、网络数据,甚至代码逻辑。

但随着外挂市场的发展,外挂衍生出其它恶意变种。这类外挂不会影响游戏数据和逻辑,例如脱机挂、模拟器和脚本精灵
在这里插入图片描述

脱机挂是外挂作者逆向游戏协议后独立开发的非法客户端,能让玩家节约很多时间多开刷游戏;模拟器能让玩家在PC上玩移动游戏,在FPS等游戏上能获得更好的操作环境,从而帮助玩家变相碾压对手;脚本精灵则是能录制模拟玩家行为,对游戏事件进行响应,实现自动刷金币经验等功能。但这几类新兴外挂有个共同特性:即是欺瞒游戏服务器,欺瞒客户端、设备和操作者。

2.外挂的分类及实现原理

无论端手游,市面上已经出现过大量外挂样本,根据其特征可整理为下图所示的分类图。
123

总的来说,外挂可分为两大类:辅助和破解版,这两类外挂的核心区别在于:是否需要依赖游戏客户端。辅助类外挂是需要结合游戏客户端运行的;而破解版则是可独立运行的非法客户端。

2.1 辅助类外挂

辅助类外挂需要依赖游戏客户端,不能独自生效。根据其作用范围可以再划分为两个小类:专用插件和通用工具。

实现原理:
辅助类外挂是基于游戏客户端,动态修改游戏数据类型外挂。

2.2 专用插件类外挂

专用插件类外挂,作用范围只针对特定游戏,属于定制化外挂。其存在形式依据平台不同而有所区别,在Android下以SO形式,而在IOS下以dylib形式。其内部集成了多款Android手游功能插件,针对不同手游注入不同SO实现外挂功能。

类似的IOS上也出现过相关辅助,针对多款热门手游注入不同Dylib实现无敌、秒怪功能功能。这类专用插件外挂,外挂功能较为灵活,一般都可随时关闭或者开启。

在这里插入图片描述

实现原理:
专用插件类外挂,属于定制化外挂,每个外挂只针对一款游戏。这类外挂的实现顾名思义,是插件形式:利用注入技术将功能模块注入到游戏进程空间中,并执行功能模块入口函数。外挂功能模块在被注入到游戏进程后,会执行HOOK操作实现外挂功能。

在底层汇编,HOOK操作可以理解为在特定代码地址,增加个跳转指令跳转到外挂作者自定义函数中。

因此,专用辅助可以很灵活修改游戏代码逻辑,通过多次回调怪物扣血函数实现秒怪、通过屏蔽玩家扣血函数实现无敌等。

2.3 通用工具

顾名思义,通用工具是针对所有游戏,其支持的是通用功能。

实现原理:
该类外挂工具,平台或者游戏引擎相关,跟具体游戏无关,实现的是跨游戏的一类外挂功能。

2.4 内存修改器

用来搜索修改游戏内存数据。在Android平台上较为主流。玩家一般根据游戏面板中的精确数据,利用修改器搜索相应数值,再根据数值变化规律多次搜索排除定位到相应属性在内存中的位置,直接修改成夸张效果值。

后期也有各种变种,比如模糊搜索,仅通过数据变大变小来搜索;加密搜索,带有反简单加密(异或加密等)功能搜索。这类修改器外挂,常见外挂功能是改人物属性实现秒怪、无敌等。

在这里插入图片描述

实现原理:
内存修改器外挂功能本质是实现对指定进程内存数据的读写。其实现技术主要体现在如何读写游戏内存数据上。

2.5 变速器

变速器外挂主要作用是加快游戏节奏,节省玩家时间;或者减慢游戏节奏,减低操作难度。其影响游戏帧更新频率,可实现加速过关、减速躲技能等外挂功能。常见外挂功能均是在游戏对局中,利用变速器加速功能,主角和怪物AI的攻击节奏加快,能快速结束战斗。

实现原理:
通常游戏需要以帧为单位播放画面,播放画面过程中计算每帧动画播放所需时间(也可理解为两个画面切换的间隔时间),游戏需要调用C库函数获取系统时间以供计算每帧更新。

2.6 按键精灵

模拟用户按键。简单版本是直接录制一段固定按键序列,然后循环模拟该按键序列。后续发展成可识别图像触发特定按键。常见于刷部分等重复性操作较多的手游。比如某飞机游戏中,可利用按键精灵随机移动飞机刷副本攒取金币经验。

实现原理:
调用系统API,发送特定操作序列,模拟用户按键。这类外挂功能的实现,和系统相关性较大,因为其实现是通过相应系统API发送操作事件模拟全局按键。

2.7 模拟器

让玩家可在PC上运行手游。这类工具是在PC端运行。由于PC有较好的鼠标、键盘操作手感,这类外挂工具用在FPS或格斗手游上。FPS上能快速滑动视角瞄准开枪,格斗手游上能风骚走位释放连招等。

实现原理:
PC上的模拟器,其核心实现,还是基于VirtualBox模拟Android系统,可直接模拟x86架构的Android系统。

抓包工具
用于拦截游戏的上下行数据包,可篡改、重发、丢弃。针对没有进行协议加密的游戏,这类外挂工具的危害较大。比如某格斗游戏中曾出现下发人物属性数据包是明文的现象,被玩家发现后玩家直接修改相应属性成较大值即实现了秒怪功能。

该工具主要是利用游戏协议方面的漏洞,一方面是协议内容是否加密好;另一方面是协议设计是否存在逻辑漏洞(重发、丢弃数据包是否会出现外挂功能)。

实现原理:
本质是网络数据包编辑器。一类实现方式是基于硬件,比如让网卡处于混乱模式,即可拦截数据包;另一类则是通过HOOK,针对send和recv类函数进行拦截,获得网络数据包。

2.8 破解版

破解版类外挂本质上是一个非法客户端。常见能分为两类:脱机挂和小修小改的破解版。

脱机挂,是外挂作者基于游戏协议的分析,自己开发的一个游戏客户端。通常情况下,这类客户端都可用来多开直接刷副本等功能,收益巨大。工作室对这类外挂的需求较大。

受损破解版,这里采用受损来定义是因为此类破解版是基于正版客户端修修改改实现的。其功能相对辅助类外挂灵活性不够,一般是一类破解版固定开启一类外挂功能,游戏过程中无法关闭。

在这里插入图片描述

实现原理:
破解版是通过事先静态修改后的独立的游戏客户端。前面提到的一种脱机挂,在端游上盛行一时。外挂作者前期逆向分析了游戏的网络协议后,可自己编写独立三方客户端。这类外挂技术难度较高,主要体现在逆向分析游戏协议上面。

另一类则是对游戏客户端修修改改后实现的游戏破解版。可以根据修改的客户端数据不同分类:逻辑代码和数据资源。

分析调试,这类实现效果和替换法一样,但其前期是通过静态分析或者动态调试分析确认资源的作用和加密方式。

本期内容专业、全面地分析了外挂的种类、功能及实现原理。当然现有的外挂实现方法也不止上文提到的这几种,现在高端一点的,也可以直接制作出“AI辅助挂”、“AI自瞄挂“等。

https://www.bilibili.com/video/BV1VZ4y1U73t?spm_id_from=333.337.search-card.all.click
在这里插入图片描述

好了,这期就这样了,我是leo,我们下期再见~


http://chatgpt.dhexx.cn/article/AvhVmZcP.shtml

相关文章

Windows关闭某个端口的服务

在开发过程中有些服务没有正常关闭,在重新启动新版本的服务的时候会存在端口占用的情况。就需要先停止之前的服务进程。 例如7777端口被占用。 1 查看7777端口被什么服务占用 netstat -ano | findstr 77772 停止该服务 使用taskkill /PID 55684 /T /F 这行命令停…

windows关闭端口

关闭8004端口 找到占用8080端口对应的程序的PID号 netstat -aon|findstr "8004"找到对应的程序名 tasklist|findstr "PID号"杀死程序 taskkill /f /t /im java.exe或者 taskkill /pid 7952 /F

win10防火墙怎么关闭端口?

我们都知道win10系统自带防火墙功能,如果用户使用的是公用网络,防火墙就会提醒各种问题。有很多用户使用完端口想要关闭,但是不知道如何关闭。下面小编就给大家讲讲如何关闭防火墙端口的方法。 若要关闭Microsoft Defender防火墙中的端口&…

关闭Windows指定端口

Windows默认情况下,很多端口是开发的,这就给网络病毒或黑客通过这些开放的端口登录你的电脑提供的机会。 可以采用Zenmap工具扫描指定ip所开放的端口,且应在局域网和互联网等条件下进行端口扫描,保障端口的开放的可控&#xff0c…

windows10 关闭指定端口

今天在Windows10电脑上安装zk和dubbo,运行Tomcat总是包端口占用异常,重启了一次电脑后觉得一直重启不是个好办法,于是学会了用命令关闭进程的技能 查看指定端口的使用情况 使用命令: netstat -ano | findstr 端口号1 如下所示&…

win10关闭某个端口

前言 作为一个程序员,经常遇到启动某个软件时,会爆出某个端口被占用,所以使用命令关闭端口的技能必须掌握 第一步:查询端口对应的PID netstat -ano|findstr 1099 第二步:根据PID关闭该进程 【F参数:表…

WINDOWS10如何关闭占用的端口号

WINDOW10 如何关闭占用的端口号 今天运行服务的时候,发现报错。 Web server failed to start. Port xxxx was already in use.这里的’xxxx‘是端口号。原因是程序没关闭,电脑就关机了,因此再次运行该程序的时候发现端口号被占用。 这样的…

Windows系统关闭端口教程

打开控制面板----管理工具----本地安全策略 单击选中“IP安全策略在本地计算机”,在右侧空白处右击,选择创建IP安全策略 点击下一步 输入新建策略的名称----点击下一步 下一步 单击完成 在新IP安全策略属性窗口下 新建安全规则----单击添加 单击添加 在…

Debian上如何打开关闭端口

1. 可以通过"netstat -anp" 来查看哪些端口被打开。 (注:加参数-n会将应用程序转为端口显示,即数字格式的地址,如:nfs->2049, ftp->21,因此可以开启两个终端,一一对应一下程序所…

windows关闭端口命令cmd

打开命令行窗口 输入 netstat -ano |findstr (需要关闭的端口) 比如要关闭8081这个端口 输入 taskkill /t /f /im (根据端口得到的进程号) 例如: 21500就是上面查到的进程号

Windows端口开启关闭

亲测可用,若有疑问请私信 netstat-a #显示所有活动的TCP连接以及计算机监听的TCP和UDP端口。 netstat-e #显示以太网发送和接收的字节数、数据包数等。 netstat-n #以数字形式显示所有活动的TCP连接的地址和端口号。 netstat-o #显示活动的TCP连接并包括每个连…

Linux下开启、关闭端口的方法

Linux下开启、关闭端口的方法 1、查看防火墙状态2、开启防火墙3、开启端口(以端口443为例)4、重启防火墙5、重新载入防火墙6、查看已开启的端口7、如何关闭端口 1、查看防火墙状态 在Linux控制台输入:firewall-cmd --state 此时控制台返回&a…

Windows如何关闭端口(图文)

方法1:创建防火墙策略进行阻止端口(防火墙开启才生效) 方法2:本地安全策略关闭 控制面板--系统--管理工具--本地安全策略 新建安全策略 去掉添加向导的勾选,添加筛选器列表 设置ip地址 设置协议类型 设置端口 添加筛…

命令行关闭端口

1.打开cmd(winR或者搜索框搜索cmd) 2.netstat -ano | findstr :8082 3.taskkill /F /PID 25108 附:如果结束端口提示不成功请使用管理员权限打开cmd在执行前面的步骤即可

cmd关闭端口

cmd关闭端口的命令是“taskkill”,该命令用于结束一个或多个任务或流程。关闭端口的方法:1、使用“taskkill /pid 端口号 -t -f”命令来强制关闭;2、使用“taskkill /f /t /im 进程名”命令来关闭。 通过CMD命令行打开防火墙端口 Windows 使用…

windows端口占用关闭指定端口

项目无法启动,端口冲突 1、查看windows端口进程 点击开始菜单选择运行(winr),接着在运行对话框中输入“cmd”,回车打开命令提示符窗口,然后在窗口中输入【netstat -aon|findstr “端口”】,回车…

windows系统关闭指定端口

一、在dos窗口中输入指令:netstat -ano | findstr 9095,其中9095是指你指定的端口号,然后会显示出现在占用该端口号的pid。 二、输入 taskkill /f /pid 5372,关闭该进程即可

windows系统关闭指定的端口

【win】 【r】打开cmd窗口 使用【netstat -nao】查看所有的IP和端口。 在cmd窗口中输入【netstat -ano | findstr 8800】指令,8800是你需要关闭的端口号。 然后再输入【taskkill /f /pid 14328】关闭这个进程即可。

windows关闭端口方法

在介绍各种端口的作用前,这里先介绍一下在Windows中如何关闭/打开端口,因为默认的情况下,有很多不安全的或没有什么用的端口是开启的,比如Telnet服务的23端口、FTP服务的21端口、SMTP服务的25端口、RPC服务的135端口等等。为了保证…

Windows的cmd中如何关闭端口

1.winr弹出程序框 2.输入cmd 3.输入 netstat -ano |findstr (需要关闭的端口) 查看本机开放的所有端口.点开始,运行,输入cmd ,回车.输入 netstat -ano 回车.可以查看本机开放的全部端口.其中Port是端口类型,其中Local Address代表本机IP地址和打开的端口…