技术人玩小游戏,如何“不战而胜”

虽然迟了一天,但还是祝各位小伙伴端午安康。

最近因为端午节到来,物业举办了一个网页小游戏,得分最高的前 N 名可以拿到奖品。

闲来无事的我参加了一下,发现自己实在是太菜了,总是玩不过别人,于是转变思路,研究看看这个小游戏是如何提交分数的。

抓包

通过 Charles 进行抓包,发现游戏结束时会调用 commit 接口提交分数。那这就好办了,因为我们可以利用 Postman 伪造请求,从而达到 “不战而胜”。

如果想了解如何抓包,可以在评论区留言,有需要的话再写一篇抓包教程。

接口分析

抓包知道哪个接口还远远不够,因为接口最重要的还是请求参数,所以我们需要弄清楚每个参数的代表的意思,一般可以参数名可以猜出来。

特殊参数

一个特殊的参数 sign,这个参数是签名的意思,由其他参数计算得到,作用是防止请求参数被篡改。因为参数发生变化,计算出来的签名也是不同的。服务端经过相同的计算,可以校验参数与签名是否匹配。

因为 sign 是计算得到的,我们伪造请求同样需要计算 sign,那么就要知道签名算法,如何知道?我们只能通过网页源码查看。

现在的网页源码大部分都是经过打包工具压缩混淆,我们想要阅读是一件比较困难的事情。但是我们只需要看提交分数的部分即可,如何快速定位代码位置?答案是通过搜索字符串来定位。

打包工具混淆代码只能修改变量名,而字符串是不能被混淆的,我们通过字符串搜索就可以稍微快速找到对应位置的代码。比如通过接口名 'commit'、参数名 'sign' 进行搜索,查看签名算法的逻辑。

请求头

很多人伪造请求,都不注意请求头的参数。例如 User-Agent 用户代理,即用户使用的浏览器标识、Cookie 一般会携带用户信息,用于区分用户。

既然要伪造请求,那就要伪造的真实一点,将抓包中显示的请求头都复制到 Postman 中(Content-Length除外)。

发起请求

一切都准备就绪,那么就可以开始利用 Postman 发起请求。因为涉及签名计算,我们可以利用 Postman 提供的 Pre-requset Script 编写请求前的计算逻辑,并将计算结果写入环境变量中,然后再使用 {{}} 进行取值。

sign 保存到环境变量中

pm.environment.set('sign', sign);

变量的使用


变量的使用

到这里就可以发起请求了,从而达到 “不战而胜” 的效果。当然了,这种做法破坏了游戏的公平性,是不可取的。不过我们可以从中吸取经验,多思考问题,提升自身的技能。

思考

换位思考一下,假如这个小游戏是我们自己开发的,那么请你思考这几个问题。

  1. 我们的应用该如何提高安全性,如何防止源码被轻易解读?
  2. 我们如何去发现识别这类伪造请求?

欢迎评论区留言讨论,也可以 wx 搜索 fe_develop6 一起在群里学习讨论。最后别忘了关注我,点赞来一波哦~

注意事项

  1. 该方法并不适用所有游戏,请自行分辨;
  2. 本文仅供学习,如产生不良后果,本文概不负责;
  3. 转载请标明出处 技术人玩小游戏,如何“不战而胜” @前端develop。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容