【游戏行业部】反外挂技术的革新:如何有效应对 FPS 外挂的威胁

news2025/1/15 7:59:42

FPS 游戏外挂现状和泛滥原因

在线多人的 FPS 游戏是实时性要求最高的游戏类型之一。在这种游戏中,玩家的一瞬间判断和反应能力会直接决定胜负。然而,网络延迟和实时加载的问题经常会导致游戏卡顿,这会极大地影响玩家的游戏体验。为了解决这个问题,FPS 游戏通常会采用预加载技术。预加载技术是指在敌人离玩家较近的时候,已经把敌人的数据从服务器下载到本地,并加载到游戏内存里。这样,在玩家和敌人真正碰面时,游戏客户端就无需再做大量的工作,从而避免实时加载受网络或设备性能影响导致卡顿。

外挂制作者利用 FPS 游戏中资源预加载在客户端本地的特性,通过修改游戏数据或注入外部程序来获得非法优势,如自瞄和透视,可以让使用者轻松击杀对手,从而获得不公平的竞争优势。这些外挂功能提供了快速且准确的瞄准能力,让使用者能够在游戏中享受虐杀快感。外挂的高收益是吸引大量玩家使用外挂的原因之一。

外挂制作者通过一些隐蔽的外挂入侵手段,以避免被反作弊系统检测到。例如使用虚拟机、内存注入、HOOK 等技术,使外挂难以被检测到。这是 FPS 游戏外挂屡禁不止的根本原因之一。

「外挂制作者->外挂销售代理->网络渠道->外挂使用者」的链条式传播和易于使用也是 FPS 游戏外挂泛滥的一个重要原因。外挂可以在模拟器运行手游的同时使用,甚至传播带有外挂功能的破解版游戏,这些方式使得外挂的使用者和影响范围变得更加广泛。

 

 

 

从网易易盾对外发布的内容来看,在 FPS 射击类游戏中外挂类型使用最多的是透视挂,占比达到 58.33%;自瞄虽然只占了 8.33%,却是最影响游戏体验的外挂。

透视

FPS 游戏为了保证低延迟的效果而将大量资源预加载在玩家客户端内存中,使得外挂制作者可以从内存中获取到各种资源的信息,并将其可视化渲染出来,这就是透视外挂的基本原理。根据透视形态的不同,可以划分为方框&血条类、面板类、自瞄圈、射线类、骨骼类、染色类等等。相较于其他类型的 FPS 外挂,透视外挂更加难以感知,只要使用者刻意伪装,即使人工审核也很难发现。

 

自瞄

如下图,在 FPS 类游戏中自瞄外挂最多的类型是模拟鼠标行为,占比达到 81.83%。外挂在获取敌人坐标后,发送模型鼠标信号,使游戏程序执行后直接将准心移动到目标位置,在驱动层面很难检测到这样的外挂。但毋庸置疑,在正常玩家与自瞄玩家的行为上,会有很大区别,即行为数据层面才是解决外挂问题的关键。

本文将以透视、自瞄外挂检测为重点进行阐述。此类外挂因为其隐蔽性高、检测难度大,缺乏实锤证据等原因使得其成为了业界的一大难题。我们从玩家行为数据的角度直接入手,深入到透视和自瞄作弊行为的本质进行检测。

传统解决方案及局限性

当前主流的检测外挂方法包括签名检测、特征检测、内存扫描等,举报审核查验以人工进行的方式为主。

  • 签名检测可以快速辨识已知外挂程序,但无法有效应对新型或修改后的外挂。

  • 特征检测监测游戏行为和操作,虽然能识别异常模式,但由于游戏的多样性和玩家行为的复杂性,依靠单一的阈值等数值进行决断,很容易产生误报,并且会有一定的遗漏。

  • 内存扫描虽然能够通过检测内存中的外挂代码或数据结构来发现外挂,但外挂制作者可以采取一些对抗措施来规避此方法,例如使用加密算法、随机化内存地址等手段。因此,内存扫描并非完全可靠的外挂检测方法,需要结合其他检测手段来提高检测的准确性和可靠性。

人工举报审核可及时发现外挂行为,但由于举报者的主观性和游戏玩法的复杂性,可能存在误报和恶意举报的情况。

传统解决方案的优点是效果明显,但缺陷在于对抗程度高且存在严重的滞后性,外挂更新频繁且善于隐藏进程,传统方案很容易失效,迭代升级后才能扫描到外挂进程,如此一来便容易陷入到无止境的对抗中,消耗大量的人力和物力,最终失效。因此,对于游戏开发者来说,需要根据具体情况选择合适的方法进行检测,并不断提高反作弊系统的能力,开发更加高效、准确的检测手段,从而保证游戏的公正性和平衡性。

网易智企游戏 AI 反作弊解决方案

我们提出使用在游戏中广泛存在的回放日志数据,重构出玩家当局的表现。在回放日志数据中,我们构建了玩家的时序行为数据,并基于该时序行为数据,分别搭建了透视和自瞄外挂检测系统,该方法和系统可广泛应用于各种在线游戏平台,提高游戏平台的公平性和客户满意度。

玩家时序行为数据包括每一个时刻的位置坐标、摄像机/枪口朝向、武器类型、是否击杀、是否命中等信息,在此基础之上我们进行二次设计加工,构造每个时刻的准心移动的速度、加速度和目标相对移动轨迹、相对偏向角、目标是否在视野内等特征,再往上一层,构造以“开火、命中、击杀、回合、对局、玩家历史对局”渐进地多层次维度的特征。

透视和自瞄是 FPS 游戏里不同类型的作弊问题,我们从同一个时序行为数据中提取多个特征,其中我们发现部分特征非常明显且富于表达,呈现出正常玩家与作弊玩家的巨大差异性。我们将多个特征构成的序列喂入模型进行预训练,得到表征之后再进行分类监督学习,最后对玩家是否作弊进行预测。该方案采用自监督时序模型对玩家行为数据进行建模,过程分为三个阶段:

  • 在第一阶段,通过对历史玩家对局数据进行对比构造样本,将上述信息输入到模型中进行学习,该模型能够自主学习游戏玩家的行为模式和数据特征。

  • 在第二阶段,使用少量有标签的历史玩家数据进行监督学习,从而更好的学习到数据的潜在表示。

  • 在第三阶段,模型对游戏玩家每场行为数据进行处理,以检测其是否存在透视或自瞄外挂行为。

基于时序行为数据的透视外挂检测方案

作弊玩家使用透视外挂,获取了正常玩家不具备的视野和整体宏观信息优势,也正因为如此,他们的行为表现的与正常玩家有所不同,例如能在视野信息未知的情况下进行走位和瞄准,从而获取对枪时的优势,在目标掩体后暴露瞬间会有超出正常水平的瞄准击杀表现,落在数据上有诸多特征维度可以进行区分,本文我们选取 2 个最为明显的维度进行展示:关键时刻目标相对偏向角的变化,以及综合多个击杀/多回合的瞄准击杀表现。

1. 关键时刻目标相对偏向角的变化

作弊玩家使用透视后,一般会有很多有意识或无意识的“预瞄准”现象,使得目标相对偏向角的变化曲线与正常玩家不同。

 

可以看到,在关键时刻例如击杀前目标在墙后移动的时候,透视作弊玩家的目标相对偏向角比正常玩家总体偏低,且变化较为稳定。

2. 综合多个击杀、多回合的瞄准击杀表现

作弊玩家在目标遮挡到“视野暴露”的瞬间,能够在很短的时间内完成瞄准与击杀,与普通玩家的正常反应时间呈现出较大的差距,该差距在综合多次击杀、多回合表现的情况下尤为明显。


 

如上图所示,尽管作弊玩家偶尔会“演”,正常玩家也会有偶尔“超神”表现,但是放大到单回合多次击杀,以及多回合、多场次的瞄准击杀表现来看,透视作弊玩家的平均反应时间(命中时间差)要比正常玩家低,且稳定,而平均击杀率(对枪 KD)则比正常高。

基于时序行为数据的自瞄外挂检测方案

我们分析发现,使用自瞄外挂的作弊玩家在准星移动速度、加速度、准星落点等多维度特征上与正常玩家表现有明显差异。这是因为自瞄外挂能够快速锁定敌人,使得玩家的瞄准更加精准和迅速,而正常玩家则需要花费更多的时间和精力进行瞄准。具体来说,自瞄外挂使用者的准星移动速度和加速度更快,准星在敌人球面的落点更加集中。这些特征的显著差异导致了自瞄外挂使用者的表现与正常玩家不同。

1. 准心移动速度与其加速

通过下图,蓝色曲线为准心移动速度红色曲线为其加速度,红色坐标点为玩家开枪时刻,自瞄程序通常会使准心的移动速度和加速度变得非常平滑,因为它们会获取目标的位置并自动调整准心的移动速度和加速度。左图为自瞄玩家,右图为正常玩家,相比之下,正常玩家的准心移动速度和加速度可能更加杂乱和不规则。我们可以看出自瞄玩家在开枪后依然可以保持较小的速度与加速度变化(丝滑压枪效果)。

 

2. 准心在敌人球面的落点

因为自瞄提前获取了玩家的某个部位坐标,再模拟鼠标信号发送信号,以下是准心在敌人球面的落点图,左图为自瞄玩家,右图为正常玩家,可以看到准心落在敌人所在球面时,自瞄玩家的准心轨迹会更加平滑,不会出现正常玩家那样准心的大规模角度变化。

 

时序模型网络架构

如上,将我们通过业务经验、专家经验构造的透视和自瞄的时序特征进行提取之后,结合原始特征,按照“命中、击杀”的时间顺序组合形成序列,喂入到自监督时序模型进行预训练,再经过 LSTM 序列分类网络进行监督学习。

 

应用效果

 

我们在某知名 FPS 游戏上部署了该系统,系统将模型推理服务部署在服务器上,客户端通过埋点日志和实时推流的方式上传解析后的回放数据,服务端实时接收玩家每个回合、每局的时序行为数据(视网络条件而定),并进行特征处理和结果推理,同时会结合玩家历史对局信息做出综合决策,决策结果存盘并经过复核之后,游戏对作弊玩家进行处理。

我们从国内外网站上收集了 10w 场的回放数据,解析出 67w 玩家总共 1000w 次击杀样本,在业务方线上 3 千场比赛数据中,高召回方案可覆盖自瞄玩家总数的 82.94%,高精度方案可获得 95.38% 的准确度。

总结与未来工作展望

通过对 FPS 游戏主流外挂以及传统解决方案的分析,我们不难看出这是矛与盾对决的巅峰之战,利用人工智能等先进技术才能够更准确地检测外挂行为。

在面对复杂的外挂形势,网易智企游戏 AI 经过多年的技术沉淀积累,以足够多的游戏大数据做基础支持,打磨出完善的 FPS 游戏反作弊数据解决方案。


方案仅通过使用在游戏中广泛存在的回放日志数据,重构出玩家当局的表现,构建玩家的时序行为数据,并基于该时序行为数据,分别搭建透视和自瞄外挂检测系统。该方法和系统可广泛应用于各种在线游戏平台,提高游戏平台的公平性和客户满意度。

未来,游戏开发者和平台运营商需要不断更新和完善反外挂系统。在反外挂技术方面,需要继续研究和开发更加高效、准确的算法和模型,以应对不断变化的外挂形式和攻击手段。同时,需要加强对游戏平台的监管和管理,建立健全的监管机制,加强对玩家行为的监测和识别,及时发现和处理违规行为,维护游戏的公平性和品牌形象。此外,游戏开发者和平台运营商还需要与玩家建立更紧密的联系,了解玩家的需求和反馈,及时解决玩家的问题和困惑,提高玩家的满意度和忠诚度。最终,通过不断更新和完善反外挂系统,加强对游戏平台的监管和管理,以及与玩家的密切联系,可以有效地保护游戏的公平性和品牌形象,提高游戏平台的用户体验和市场竞争力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/780612.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java-WebSocket

请点击下面工程名称,跳转到代码的仓库页面,将工程 下载下来 Demo Code 里有详细的注释 TestWebSocket

解读Lawyer LLaMA,延申专业领域大模型微调:数据集构建,模型训练

解读Lawyer LLaMA,延申自己领域大模型微调:数据集构建,模型训练 项目地址link 自己领域的大模型微调,实现思路大都和这篇文章是一样的,有的是基于LLaMA,或者有的是基于Chinese-LLaMA,或者是其他开源的大模型&#xf…

对话网心科技李浩| 携“边缘云+AI”之势,深入拓展算力业务场景落地

// 以ChatGPT为代表的人工智能的应用正加快改变人们的生活和工作方式,各种AI的应用引发了新一轮的音视频内容的生产力革命。而伴随着海量的音视频内容的生成,大量的内容会在边侧创建和存储,并在边端完成计算和分发。网心科技持续专注边缘云…

【论文阅读】2020ECCV-DFDNet

Blind Face Restoration via Deep Multi-scale Component Dictionaries 中文:基于深度多尺度分量字典的盲人脸复原 paper: code:https://github.com/csxmli2016/DFDNet 摘要: 近年来,基于参考的人脸恢复方法因其在真…

windows系统修改mysql8配置文件,关闭ssl验证

如何寻找配置文件 我的电脑,右键,管理,服务 找到MySQL8 右键,属性 找到配置文件位置 通常情况下的默认路径是: C:\ProgramData\MySQL\MySQL Server 8.0\my.ini 如何关闭SSL验证 打开 my.ini 配置内容如下&#x…

JAVA基础-集合的工具类Collections

目录 引言 一,Collections工具类的操作方法方法 1,排序操作 2,替换 和 查找操作 二,Collections工具类的使用 2.1,排序操作 2.1.1,集合的逆序 2.1.2,集合的随机排序 2.1.3,集…

第一百一十三天学习记录:C++提高:类模板(黑马教学视频)

类模板 类模板语法 类模板作用&#xff1a; 建立一个通用类&#xff0c;类中的成员 数据类型可以不具体定制&#xff0c;用一个虚拟的类型来代表。 语法&#xff1a; template<typename T> 类解释&#xff1a; template … 声明创建模板 typename … 表面其后面的符号…

SpringCloud nacos 集成 gateway ,实现动态路由

&#x1f388; 作者&#xff1a;Linux猿 &#x1f388; 简介&#xff1a;CSDN博客专家&#x1f3c6;&#xff0c;华为云享专家&#x1f3c6;&#xff0c;Linux、C/C、云计算、物联网、面试、刷题、算法尽管咨询我&#xff0c;关注我&#xff0c;有问题私聊&#xff01; &…

LeetCode刷题笔记 - 859. 亲密字符串

LeetCode刷题笔记 - 859. 亲密字符串 运行结果 题目注意点 bool buddyStrings(char* s, char* goal) {char d 0;char gd 0;int pair 0;int epair 0;char map[256] {0};if (strlen(s) ! strlen(goal)) {return false;}while (*s ! \0) {if (*s ! *goal) {if (d 0) {d *s;…

《Kali渗透基础》09. 漏洞利用、后渗透

kali渗透 1&#xff1a;漏洞基本介绍1.1&#xff1a;漏洞从哪里来1.2&#xff1a;缓冲区溢出1.3&#xff1a;如何发现漏洞 2&#xff1a;漏洞利用2.1&#xff1a;EXP 选择与修改2.2&#xff1a;避免有害的 EXP 3&#xff1a;后渗透阶段3.1&#xff1a;Linux 上传文件3.2&#x…

前后端分离windows本地nginx解决跨域

下载 http://nginx.org/en/download.html 命令 启动Nginx&#xff1a; nginx.exe start 快速停止或关闭Nginx&#xff1a; nginx.exe -s stop 正常停止或关闭Nginx&#xff1a; nginx.exe -s quit 配置文件修改重装载命令&#xff1a; nginx.exe -s reload 强制停用…

六边形架构

六边形架构 微服务系统架构微服务定义微服务系统设计 传统分层架构六边形架构参考资料 微服务系统架构 需求描述做什么的问题&#xff0c;架构描述怎么做的问题(描述组成系统的各部件及其之间的关系) 微服务定义 下面的定义来自周志明老师的 凤凰架构 微服务是一种通过多个小型…

2023牛客暑期多校第一场部分题解

索引 BCDHJKLM B 官方题解说是乱搞题&#xff0c;而我队友实际上也确实乱搞过去了&#xff08; 就是先随便取两个点&#xff0c;有了两个点之后第三个点肯定选离这两个点构成的直线最远的那个&#xff0c;要不然没法包含整个凸多边形。这个过程可以用个三分。 但是确定了第三…

前端(八)——深入探索前端框架中的Diff算法:优化视图更新与性能提升

&#x1f60a;博主&#xff1a;小猫娃来啦 &#x1f60a;文章核心&#xff1a;深入探索前端框架中的Diff算法&#xff1a;优化视图更新与性能提升 文章目录 前端框架中的Diff算法概述vue和react框架的diff算法React的diff算法&#xff1a;Vue的diff算法&#xff1a; Diff算法在…

实训笔记7.20

实训笔记7.20 7.20一、座右铭二、HDFS宕机之后的副本数的问题三、MapReduce的工作流程&#xff08;简单版本&#xff09;四、Hadoop的序列化问题五、MR程序运行中InputFormat类的作用5.1 作用主要有两个5.2 有一个核心实现类--抽象类FileInputFormat 当输入的数据是文件的时候5…

【图像分类】基于LIME的CNN 图像分类研究(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f308;4 Matlab代码实现 &#x1f4a5;1 概述 基于LIME&#xff08;Local Interpretable Model-Agnostic Explanations&#xff09;的CNN图像分类研究是一种用于解释CNN模型的方法。LIME是一…

实用的设计模式08——适配器模式

适配器的单词是Adapter&#xff0c;我们在开发时经常碰到叫做XxxAdapter的类&#xff0c;此时一般就是使用了适配器模式&#xff0c;适配器模式是非常常用&#xff0c;本文就对适配器模式做一个简单的介绍 文章目录 1、真实开发场景的问题引入2、适配器模式讲解2.1 核心类及类图…

2021年全国大学生电子设计竞赛H题——用电器分析识别装置

用电器分析识别装置 一、题目要求二、系统方案三、硬件设计3.1、ATT7022电参数采集模块 一、题目要求 任务 设计并制作一个根据电源线电流的电参量信息分析在用电器类别的装置。该装置具有学习和分析识别两种工作模式。在学习模式下&#xff0c;测试并存储用于识别各单件电器的…

百亿规模京东实时浏览记录系统的设计与实现 | 京东云技术团队

1. 系统介绍 浏览记录系统主要用来记录京东用户的实时浏览记录&#xff0c;并提供实时查询浏览数据的功能。在线用户访问一次商品详情页&#xff0c;浏览记录系统就会记录用户的一条浏览数据&#xff0c;并针对该浏览数据进行商品维度去重等一系列处理并存储。然后用户可以通过…

mybatis事物是如何和spring事物整合的

目录 1、mybatis事物管理器 2、SpringManagedTransactionFactory如何处理事物 3、spring事物如何设置connection连接到threadLocal 1、mybatis事物管理器 mybatis事物抽象接口类&#xff1a;Transaction。该接口定义了事物基本方法和获取数据库连接方法 该类有三个实现类Jd…