通過(guò)Python實(shí)現(xiàn)自動(dòng)填寫(xiě)調(diào)查問(wèn)卷
0X00 前言
快開(kāi)學(xué)了,看到空間里面各種求填寫(xiě)調(diào)查問(wèn)卷的,我才想起來(lái)貌似我也還沒(méi)做。對(duì)于這種無(wú)意義的問(wèn)卷,我是不怎么感冒的,所以我打算使用”特技”來(lái)完成,也就是python,順便重新復(fù)習(xí)一下python,真的好久沒(méi)用了。下面,表演開(kāi)始……
0X01代碼編寫(xiě)思路
首先先創(chuàng)建一份問(wèn)卷
我們隨便填寫(xiě)一個(gè)問(wèn)卷并提交,在提交之前開(kāi)啟Burpsuite截獲數(shù)據(jù)包
對(duì)于截獲的數(shù)據(jù)包進(jìn)行分析,有的被url編碼了不利于分析,可以使用Burpsuite編碼模塊解碼替換,這樣就好分析了
通過(guò)觀察可以發(fā)現(xiàn),post了一串奇怪的數(shù)據(jù)submitdata=1$2}2$3}3$3}4$4}5$3}6$2}7$4}8$2}9$3}10$3。仔細(xì)分析可看出數(shù)據(jù)大概是這個(gè)意思submitdata=題號(hào)$選項(xiàng)號(hào)}題號(hào)$選項(xiàng)號(hào)}題號(hào)$選項(xiàng)號(hào)}……..
利用這些信息就可以開(kāi)始編寫(xiě)python程序了
運(yùn)行結(jié)果如下
貌似網(wǎng)站還有其他反爬蟲(chóng)機(jī)制,在連續(xù)提交幾個(gè)表單之后,就出現(xiàn)了驗(yàn)證碼。難道此時(shí)我們還要給程序添加上識(shí)別驗(yàn)證碼的功能?其實(shí)不必,我們可以先分析一下剛剛Burpsuite截獲的header信息,來(lái)看看到底網(wǎng)站是通過(guò)什么方式,識(shí)別出我們是用爬蟲(chóng)來(lái)提交問(wèn)卷的。
通過(guò)一番測(cè)試,我發(fā)現(xiàn)當(dāng)我連續(xù)提交3份問(wèn)卷,再換一個(gè)IP提交3個(gè)問(wèn)卷,也就是連續(xù)提交了6份問(wèn)卷,并沒(méi)有觸發(fā)網(wǎng)站的反爬蟲(chóng)機(jī)制。所以我們可以猜測(cè)對(duì)方基于IP提交問(wèn)卷的頻率來(lái)識(shí)別爬蟲(chóng)程序的??吹竭@里,大家可能會(huì)想,我們可以通過(guò)網(wǎng)上的免費(fèi)代理來(lái)提交問(wèn)卷。例如這些
那是不是意味著我們還要往python代碼中添加提取免費(fèi)代理IP的功能呢?NO NO NO!換個(gè)思路,在CTF比賽中會(huì)遇到一種題目,例如你的IP是來(lái)自德國(guó)的才可以拿到flag。所以,我們的思路就是進(jìn)行數(shù)據(jù)包頭欺騙,偽造我們的IP,騙過(guò)服務(wù)器。下面來(lái)說(shuō)說(shuō)偽造IP的幾種方式。
X-Client-IP:1.1.1.1 X-Remote-IP:2.2.2.2 X-Remote-Addr:3.3.3.3 X-Originating-IP:4.4.4.4 X-Forwarded-For:5.5.5.5
我們每個(gè)都嘗試一下,然后在后臺(tái)統(tǒng)計(jì)那里可以看到我們的問(wèn)卷來(lái)源
這里我們發(fā)現(xiàn)用X-Forwarded-For可以繞過(guò),按我們就用這種方法在header信息中添加X(jué)-Forwarded-For字段,所以修改后的腳本如下
運(yùn)行結(jié)果如下
再到后臺(tái)看看統(tǒng)計(jì)信息
至此,我們算是完美的解決任務(wù)了。如果大家想去掉調(diào)查問(wèn)卷中國(guó)外的IP地址,可以收集一下中國(guó)的IP地址段,然后添加進(jìn)程序,處理一下即可。
0X02總結(jié)
大家平??梢园褜W(xué)到的東西用到實(shí)際生活中,遇到困難的時(shí)候不要慌,多思考,找到最優(yōu)的解決方法。例如上面,我并沒(méi)有在代碼中添加驗(yàn)證碼識(shí)別模塊,也沒(méi)有通過(guò)走代理的方式來(lái)繞過(guò)網(wǎng)站的反爬蟲(chóng)機(jī)制,而是通過(guò)分析網(wǎng)站的反爬蟲(chóng)機(jī)制,并且使用所學(xué)的安全知識(shí)(HTTP頭欺騙)輕松解決問(wèn)題,使用最短的代碼完美完成任務(wù)。
相關(guān)文章
Python繪制地圖神器folium的新人入門(mén)指南
folium庫(kù)是一個(gè)用于完成地圖可視化的Python擴(kuò)展庫(kù),下面這篇文章主要給大家介紹了關(guān)于Python繪制地圖神器folium入門(mén)的相關(guān)資料,需要的朋友可以參考下2021-05-05Python內(nèi)建模塊collections實(shí)現(xiàn)特殊容器數(shù)據(jù)類(lèi)型
collections模塊是Python的內(nèi)建模塊之一,它實(shí)現(xiàn)了特殊的容器數(shù)據(jù)類(lèi)型,提供了Python內(nèi)建的數(shù)據(jù)類(lèi)型dict、list、set、和tuple的高效替代選擇2023-06-06深入理解Python虛擬機(jī)之進(jìn)程、線(xiàn)程和協(xié)程區(qū)別詳解
在本篇文章當(dāng)中深入分析在 Python 當(dāng)中 進(jìn)程、線(xiàn)程和協(xié)程的區(qū)別,這三個(gè)概念會(huì)讓人非常迷惑,如果沒(méi)有深入了解這三者的實(shí)現(xiàn)原理,只是看一些文字說(shuō)明,也很難理解,在本篇文章當(dāng)中我們將通過(guò)分析部分源代碼來(lái)詳細(xì)分析一下這三者根本的區(qū)別是什么,需要的朋友可以參考下2023-10-10PyQt5+QtChart實(shí)現(xiàn)柱狀圖的繪制
QChart是一個(gè)QGraphicScene中可以顯示的QGraphicsWidget。本文將利用QtChart實(shí)現(xiàn)柱狀圖的繪制,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-12-12python利用matplotlib庫(kù)繪制餅圖的方法示例
Python強(qiáng)大的原因之一就在于其開(kāi)源,有很多優(yōu)秀的程序員為其提供了豐富的類(lèi)庫(kù)。Matplotlib就是其中之一,下面這篇文章主要介紹了python如何利用matplotlib庫(kù)繪制餅圖的方法示例,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-12-12Python讀取圖片屬性信息的實(shí)現(xiàn)方法
這篇文章介紹了利用Python讀取圖片屬性信息的方法,讀取的內(nèi)容包括GPS 信息、圖片分辨率、圖片像素、設(shè)備商、拍攝設(shè)備等,有需要的朋友們可以參考借鑒。2016-09-09