通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

這篇文章將為大家詳細(xì)講解有關(guān)通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

為隆昌等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及隆昌網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、隆昌網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

一、教程簡(jiǎn)介

1.1 基本介紹(私信小編001 、002 、003 、007任何一個(gè)即可獲取Python學(xué)習(xí)資料)

通過(guò)分析登陸流程并使用 Python 實(shí)現(xiàn)模擬登陸到一個(gè)實(shí)驗(yàn)提供的網(wǎng)站,在實(shí)驗(yàn)過(guò)程中將學(xué)習(xí)并實(shí)踐 Python 的網(wǎng)絡(luò)編程,Python 實(shí)現(xiàn)模擬登陸的方法,使用 Firefox 抓包分析插件分析網(wǎng)絡(luò)數(shù)據(jù)包等知識(shí)。

模擬登錄可以幫助用戶自動(dòng)化完成很多操作,在不同場(chǎng)合下有不同的用處,無(wú)論是自動(dòng)化一些日常的繁瑣操作還是用于爬蟲(chóng)都是一項(xiàng)很實(shí)用的技能。本課程通過(guò) Firefox 和 Python 來(lái)實(shí)現(xiàn),環(huán)境要求如下:

Python 庫(kù):urllib, http.cookiejar, Django

Firefox 要求:裝有 live http header插件 (已提供)

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

1.3 材料

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

1.4 準(zhǔn)備

1) 安裝抓包插件Live Http Headers

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

2)啟動(dòng)web應(yīng)用

使用 ps -aux | grep codebox 查詢獲得 codebox 的進(jìn)程號(hào),然后使用 kill -9 進(jìn)程號(hào) 停止 codebox 進(jìn)程。執(zhí)行過(guò)程見(jiàn)下圖:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

首先安裝demo依賴的web框架django,并測(cè)試是否安裝成功:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

啟動(dòng)成功后在瀏覽器中輸入 http://localhost:8000/polls 看到登錄頁(yè)面表示啟動(dòng)成功

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

二、分析登錄過(guò)程

要通過(guò)編程實(shí)現(xiàn)登錄,首先需要理解一般Web應(yīng)用的登陸過(guò)程。

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

2.1 抓取請(qǐng)求

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

2.2原理分析

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

為什么是2個(gè)請(qǐng)求而不是1個(gè)呢?通過(guò)分析登錄請(qǐng)求發(fā)現(xiàn),登陸成功之后服務(wù)器發(fā)送了302重定向響應(yīng),服務(wù)器要求瀏覽器重新請(qǐng)求首頁(yè),這就產(chǎn)生了第二個(gè)請(qǐng)求。再來(lái)分析第二個(gè)請(qǐng)求,可以看到它相比登錄請(qǐng)求多了一個(gè)請(qǐng)求頭:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

整個(gè)登錄流程如下圖所示:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

服務(wù)器到底是如何區(qū)別不同用戶的session的?為什么登陸成功會(huì)后要回寫cookie呢?

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

2.3小結(jié)

對(duì)于服務(wù)器來(lái)說(shuō),登錄=驗(yàn)證+寫session。對(duì)于瀏覽器來(lái)說(shuō),登錄=發(fā)送登錄信息+獲取帶sessionid的cookie??梢哉f(shuō),只要獲得了sessionid,就算實(shí)現(xiàn)了模擬登錄。有了它我們便可以游離于系統(tǒng)之中。

三、使用Python實(shí)現(xiàn)登錄(簡(jiǎn)單實(shí)例)

理解了登錄過(guò)程的原理和細(xì)節(jié)之后,開(kāi)始用Python來(lái)編寫模擬登陸程序吧。

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

3.1導(dǎo)入模塊

不要忘記編寫文件頭、導(dǎo)入必要的依賴模塊

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

3.2構(gòu)造登錄請(qǐng)求

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

登錄請(qǐng)求的實(shí)體部分如下:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

全部Python代碼:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

附加參數(shù)

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

防盜鏈

Web 應(yīng)用的資源都是有url的,只要獲得了url就能夠在任何地方引用。聽(tīng)起來(lái)很方便,但這可能會(huì)導(dǎo)致你的資源被別人盜用。

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

3.3發(fā)送請(qǐng)求并保存cookie

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

Python代碼如下:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

如果登陸成功

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

就可以在指定的文件my_cookies.txt中看到sessionid了。

3.4 使用cookie訪問(wèn)系統(tǒng)服務(wù)

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

在我們模擬登錄成功后,就可以直接通過(guò)opener打開(kāi)這個(gè)url來(lái)使用這項(xiàng)系統(tǒng)服務(wù)。代碼實(shí)現(xiàn)如下:

通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的

如果有是在另外一個(gè)python文件中使用這個(gè)cookie的話,再打開(kāi)url之前需要先載入cookie:

關(guān)于通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

分享題目:通過(guò)抓包實(shí)現(xiàn)Python模擬登陸各網(wǎng)站的原理分析是怎樣的
文章URL:http://muchs.cn/article26/pieojg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、品牌網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)站設(shè)計(jì)公司網(wǎng)站改版、動(dòng)態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站