主頁(yè) > 知識(shí)庫(kù) > Python利用Charles 實(shí)現(xiàn)全部自動(dòng)答題思路流程分析

Python利用Charles 實(shí)現(xiàn)全部自動(dòng)答題思路流程分析

熱門標(biāo)簽:宿遷星美防封電銷卡 ai電銷機(jī)器人源碼 長(zhǎng)沙高頻外呼系統(tǒng)原理是什么 西藏房產(chǎn)智能外呼系統(tǒng)要多少錢 ai電話機(jī)器人哪里好 外呼并發(fā)線路 地圖標(biāo)注審核表 百度地圖標(biāo)注沒有了 湛江智能外呼系統(tǒng)廠家

利用Charles 達(dá)成“我是達(dá)人”答題類爆破思路
最近公司需要使用“我是答題”小程序,對(duì)武漢疫情進(jìn)行知識(shí)問題;榜單靠前的也有一定的學(xué)分獎(jiǎng)勵(lì);雖然平時(shí)總不屑于公司組織的此類活動(dòng),但是看了這次活動(dòng)形式,還是決定直接“爆破

0x01 思路18年大火的直播答題中,對(duì)某答題app也進(jìn)行了類似爆破,并薅了不少羊毛,到了后期已經(jīng)做到了全自動(dòng)化的答題,并且是100%正確正常情況下小程序和服務(wù)端通信流程

使用charles對(duì)請(qǐng)求進(jìn)行串改流程

因?yàn)槲业闹髁﹄娔X就是MacOS,所以就直接使用了Charles,當(dāng)然Windows上也有很多類似軟件,這里不再贅述。

0x02 開始我先正常完成一輪答題,可以在Charles上看到小程序和服務(wù)端的每次通信報(bào)文,通過對(duì)請(qǐng)求接口分析,大致梳理出以下兩個(gè)接口

1. 開始測(cè)試挑戰(zhàn)接口:
https://v4.21tb.com/race-mobile/mina/startRace.do

2. 上傳答案獲取下次題目接口:
https://v4.21tb.com/race-mobile/mina/userAnswer.do

對(duì)請(qǐng)求報(bào)文和返回報(bào)文分析后,確定報(bào)文的data.examItem.itemOptions[].isCorrect節(jié)點(diǎn)為正確答案。

{
    "success": false,
    "data": {
        "examItem": {
            "itemOptions": [{
                "content": "疑似或確診病例有過近距離接觸",
                "isCorrect": true
            }, {
                "content": "感冒的病人",
                "isCorrect": false
            }],
            "itemName": "什么是新型冠狀病毒密切接觸者?"
        }
    },
    "message": null,
    "status": "SUCCESS"
}

只要搭建一個(gè)中間代{過}{濾}理服務(wù),在返回給小程序時(shí)把content字段進(jìn)行修改,即可讓我們快速在小程序上看到正確答案。 本次我使用的nodejs進(jìn)行開發(fā),我對(duì)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功能

通過這一系列的配置后,就可以實(shí)現(xiàn)對(duì)小程序請(qǐng)求的中間者攻擊了最終效果,正確答案上會(huì)有個(gè)“✅”:

到此這篇關(guān)于Python利用Charles 實(shí)現(xiàn)全部自動(dòng)答題思路流程分析的文章就介紹到這了,更多相關(guān)Python實(shí)現(xiàn)全部自動(dòng)答題內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python爬取微信小程序Charles實(shí)現(xiàn)過程圖解
  • Python Charles抓包配置實(shí)現(xiàn)流程圖解
  • 從0到1使用python開發(fā)一個(gè)半自動(dòng)答題小程序的實(shí)現(xiàn)

標(biāo)簽:盤錦 普洱 南平 漯河 林芝 海南 寧夏 大同

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python利用Charles 實(shí)現(xiàn)全部自動(dòng)答題思路流程分析》,本文關(guān)鍵詞  Python,利用,Charles,實(shí)現(xiàn),全部,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python利用Charles 實(shí)現(xiàn)全部自動(dòng)答題思路流程分析》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python利用Charles 實(shí)現(xiàn)全部自動(dòng)答題思路流程分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章