您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

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

51自学网 2021-10-30 22:19:41
  python
这篇教程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": "什么是新型冠状病毒密切接触者?"        }    },    "message": 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 实现全部自动答题思路流程分析的文章就介绍到这了,更多相关Python实现全部自动答题内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


女神相册密码忘记了 我只用Python写了20行代码
前女友发来加密的"520快乐.pdf",我用python破解开之后,却发现
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。