• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Python利用Charles 实现全部自动答题思路流程分析

python 搞代码 4年前 (2022-01-08) 16次浏览 已收录 0个评论

这篇文章主要介绍了Python利用Charles 实现全部自动答题思路流程分析,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

利用Charles 达成“我是达人”答题类爆破思路
最近公司需要使用“我是答题”小程序,对武汉疫情进行知识问题;榜单靠前的也有一定的学分奖励;虽然平时总不屑于公司组织的此类活动,但是看了这次活动形式,还是决定直接“爆破

0x01 思路18年大火的直播答题中,对某答题app也进行了类似爆破,并薅了不少羊毛,到了后期已经做到了全自动化的答题,并且是100%正确正常情况下小程序和服务端通信流程

使用charles对请求进行串改流程

因为我的主力电脑就是MacOS,所以就直接使用了Charles,当然Windows上也有很多类似软件,这里不再赘述。

0x02 开始我先正常完成一轮答题,可以在Charles上看到小程序和服务端的每次通信报文,通过对请求接口分析,大致梳理出以下两个接口

1. 开始测试&挑战接口:
https://v4.21tb.com/race-mobile/mina/startRace.do

2. 上传答案&获取下次题目接口:
https://v4.21tb.com/race-mobile/mina/userAnswer.do

对请求报文和返回报文分析后,确定报文的data.examItem.itemOptions[].isCorrect节点为正确答案。

 { "success": false, "data": { "examItem": { "itemOptions": [{ "content": "疑似或确诊病例有过近距离接触", "isCorrect": true }, { "content": "感冒的病人", "isCorrect": false }], "itemName": "什么是新型冠状病毒密切接触者?" } }, "messa<mark style="color:transparent">来源gaodaimacom搞#代%码网</mark>ge": null, "status": "SUCCESS" }

只要搭建一个中间代{过}{滤}理服务,在返回给小程序时把content字段进行修改,即可让我们快速在小程序上看到正确答案。 本次我使用的nodejs进行开发,我对nodejs语法还停留在新手上,将就看

 router.post('/21tb/:do', function (req, res, next) { console.log(req.params.do); fly.post('https://v4.21tb.com/race-mobile/mina/' + req.params.do + '.do', req.body, { headers: { "content-type": "application/x-www-form-urlencoded" } }) .then(d => { console.log(d.data.data) if (d.data.data) { if (d.data.data instanceof Array) { for (var inx in d.data.data) { var data = d.data.data[inx]; if (data.examItem && data.examItem.itemOptions) { var itemOptions = d.data.data.examItem.itemOptions; if (itemOptions) { for (var inx in itemOptions) { var item = itemOptions[inx] if (item.isCorrect) { item.content = '✅' + item.content; } } } } } } else { if (d.data.data.examItem && d.data.data.examItem.itemOptions) { var itemOptions = d.data.data.examItem.itemOptions; if (itemOptions) { for (var inx in itemOptions) { var item = itemOptions[inx] if (item.isCorrect) { item.content = '✅' + item.content; } } } } } } res.send(d.data); }) .catch(function (error) { console.log(error); });[/size][/font][/color][/indent][indent][color=rgb(36, 41, 46)][font=-apple-system, BlinkMacSystemFont, "][size=16px] });

再来看Charles上的配置,主要使用的Map Remote功能

通过这一系列的配置后,就可以实现对小程序请求的中间者攻击了最终效果,正确答案上会有个“✅”:

以上就是Python利用Charles 实现全部自动答题思路流程分析的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Python利用Charles 实现全部自动答题思路流程分析

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址