游戏协议测试理论(游戏测试是什么)

转载:https://blog.csdn.net/SR0ad/article/details/8253126协议测试:针对通信协议进行的测试,是对常规测试的一种补充。重要性:实现一些常规测试中无法实现的流程,修改通信数据包检测服务器异常处理,修改数据包的先后次序检查服务器处理流程。协议测试的主要测试点:1.数据类型溢出:通信双方对协议数据类型的解析不一致,导致内存操作错误。2.数据包…

大家好,又见面了,我是你们的朋友全栈君。

转载:https://blog.csdn.net/SR0ad/article/details/8253126

协议测试:针对通信协议进行的测试,是对常规测试的一种补充。

重要性:实现一些常规测试中无法实现的流程,修改通信数据包检测服务器异常处理,修改数据包的先后次序检查服务器处理流程。

协议测试的主要测试点:

1.数据类型溢出:通信双方对协议数据类型的解析不一致,导致内存操作错误。

2.数据包构造欺骗:根据数据包的规则创建出一新的数据包,填充数据包后发给server,用来模拟client的操作(比如使用某些不存在的物品)。

3.数据包重发:拦截和监听数据包,把监听到数据包重复发送给server,检测server是否有容错检查。

4.逻辑数据包先后次序:例如在未锁定情况下交易,CF在同时捡取物品时变身。

5.C/S定义数据长度字段不一致:在便携程序是未考虑到client上发送数据的安全性,未对字段ncount进行检查导致内存copy越界。

6.非正常逻辑server未做检查:例如提交任务/NPC编号不存在,发送私聊的GID不存在。

游戏协议测试优先级:背包/仓库道具系统—-交易系统—-邮件—-商城—-装备打造—-战斗技能系统—-移动系统—-帮派/家族系统

协议测试的步骤:

准备阶段(80%):系统业务的理解,协议交互流程,测试用例设计,工具选择或开发

执行阶段(10%):测试用例/场景执行,测试数据/系统数据收集

分析阶段(10%):数据汇总/日志分析,测试报告

测试工具(协议外挂):

1.HOOK目标进程的send,sendto,recv,recvform函数,监听数据包

2.揭秘解码数据包形成明文包

3.修改明文数据包

4.编码加密数据包发送到server

PS:提供加解密解码接口能快速开发使用其他业务协议明文,使用Table树方式展现,方便查看和修改协议加载方式利用,利用配置协议文件实现拦截器,自定义可以拦截指定的协议数据包。

协议测试分析:

1.结合流程图或者C/S交互图分析

数据包先后次序

数据包重发

数据逻辑(必须结合协议结构)

2.结合协议结构体分析

数据逻辑

数据包重发

数据溢出

内存越界

经典BUG分析

1.服务器未对对象合法性进行检查

e.g:自己可以和自己进行交易,修改聊天室ID导致服务器当机,修改数据包操作其他玩家

解决办法:交易,组队,聊天,人物等协议交互中标记操作者和被操作者关系的字段进行检查

2.服务器未对对象个数有效性进行检查

e.g:摆摊购物买物品数量改成-1导致刷钱,购买商场物品时修改购买个数,可以成功购买

解决办法:检测邮件删除/购买物品/物品移动/拆分,装备打造等协议字段中上报个数字段

3.服务器未对对象当前状态位置进行检查

e.g:跨越地图领取任务,骑乘状态下删除坐骑导致无法下坐骑,战斗状态下发送role登出,可进入角色列表(对象角色互斥),交易锁定的物品出售给NPC,服务器当机

解决办法:对象当前状态与操作的胡吃检查不严格,确保对象当前状态,在该中泰下进行各项操作,检查操作是否与当前状态互斥。

4.其它类型BUG

e.g:物品使用在server未做类型校验,标记类字段检查不严格(0/非0),client与server定义的数组长度不一致,前置条件不满足的情况下操作。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128741.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JavaWeb专栏之(四):什么是servlet(底层源码及执行流分析)?[通俗易懂]

    JavaWeb专栏之(四):什么是servlet(底层源码及执行流分析)?[通俗易懂]JavaWeb专栏之(四):什么是servlet(底层源码及执行流分析)?前言:本文探究JavaWeb中Servlet的源码及执行流过程,相信您看完后,为金三银四的面试中如虎添翼。俗话知其然,知其所以然。底层代码的理解擦才是YYDS,让小Du猿带您一起走进Servlet的底层实现源码吧</p>最后:本专栏的代码已经同步到Gitee中,欢迎小伙伴一键start,原创整理不易,多多支持哦!传送门:https://gitee.com/shunchangdu/Javaweb_se

    2022年6月18日
    23
  • 算法模型大全

    算法模型大全隐马尔可夫模型(HMM)http://baike.baidu.com/link?url=_NiQW91Kkdmyla_lyX1C78NVIXnzELO2l4Sr9e6FstHcss6ssmawwwZHXR7MZ_CP8ofgVTBQe-pOhmqZFx2qHKGMM(GaussianMixtureModel)-高斯混合模型http://baike.baidu.com/link?url=4zzM

    2022年6月23日
    25
  • Linux smart_linux安装smartctl

    Linux smart_linux安装smartctlSmartmontools是一种硬盘检测工具,通过控制和管理硬盘的SMART(SelfMonitoringAnalysisandReportingTechnology),自动检测分析及报告技术)技术来实现的,SMART技术可以对硬盘的磁头单元、盘片电机驱动系统、硬盘内部电路以及盘片表面介质材料等进行监测,当SMART监测并分析出硬盘可能出现问题时会及时向用户报警以避免计算机数据受损失。SMART技术必须在主板支持的前提下才能发生作用,而且SMART技术也不能保证能预报所有可能发生的硬盘故障。

    2022年10月8日
    0
  • 三维浮雕软件 linux,做3D浮雕圆雕模型用哪个软件好?3Dcoat这款软件是不错的选择。…「建议收藏」

    三维浮雕软件 linux,做3D浮雕圆雕模型用哪个软件好?3Dcoat这款软件是不错的选择。…「建议收藏」#以下是我整理了这款软件的几个优点:优点1,先进的智能转化功能,可以把彩色的平面图片生成3D浮雕模型图,也可以把灰度图生成3D浮雕图,例如在木雕家具效果图设计行业,3DCAOT制作的家具设计贴浮雕效果图优点2,它有先进的局部精细化功能,特别是用于表面精细的浮雕类工艺品设计,可以在产品的表面制作各种效果的浮雕效果。优点3,用于3D扫描抄数的后期处理,修图,对于扫描文件的表面处理,精修等。优点4,指定…

    2022年9月5日
    3
  • 图像传感器的 DVP 信号

    图像传感器的 DVP 信号一、DVP简述DVP是数字视频端口(digitalvideoport)的简称,传统的sensor输出接口,采用并行输出方式,DVP总线PCLK极限约在96M左右,所有DVP最大速率最好控制在72M以下,DVP是并口,需要PCLK、VSYNC、HSYNC、D[0:11]——可以是8/10/12bit数据,具体情况要看ISP或baseband是否支持。DVP接口在信号完整性方面受限制,速率也受限制。如图1所示,并口传输数据需要帧同步信号(Vsync

    2022年5月27日
    32
  • XML解析___使用Dom or使用Sax

    XML解析___使用Dom or使用Sax

    2021年10月3日
    220

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号