python模擬登錄并且保持cookie的方法詳解
前言
最近在爬行 nosec.org 的數(shù)據(jù),看了下需要模擬登錄拿到cookie后才能訪問(wèn)想抓的數(shù)據(jù),重要的是 nosec.org 的登錄頁(yè)面 form 中有個(gè) authenticity_token 字段每次訪問(wèn)登錄頁(yè)面都會(huì)自動(dòng)生成,而且會(huì)和你的用戶(hù)名,密碼一樣被POST到服務(wù)器。
經(jīng)過(guò)一番研究后發(fā)現(xiàn),直接訪問(wèn)網(wǎng)站登錄界面的時(shí)候,服務(wù)器的響應(yīng)頭會(huì)有一個(gè)Set-Cookie字段,如下:
_nosec_session=ZTlHNmxuZXE4R0s1UXpsVUxGRTNPblNBWFd2TXU4TU9aNWVJM2lyLzNFY0pLeUdNMDY1cmZqanpkc0ppaGtjU i9kTGdWenBrNXJKenNqbnN2YUxucE1DRW5UMHNTR1RxWDZPeGlLazllTmY1czVpYWplazJXdWkvZS9wUHJpc1Jya3ZzcmNVMytPR it2T1dEcGx4bHNDTTVzSmVTb0xhSjRycE03QUl5RXE5Z2tZWG1mTHFBWGx1QW52QjBURi8rLS1acE8yeVRtMFRZR1JWdExneStwdmpRPT0 %3D--a6ccd9a12a8af5c8b5fb6625c24bb4db0398c503; path=/; HttpOnly
而且頁(yè)面form 的表單有一個(gè) authenticity_token 的 input ,內(nèi)容如下:
<input type="hidden" name="authenticity_token" value="cGdhqVxDMRndpKbpvIV66wfEQlGf4Rz6UtXqsf79brEvFveHw2rCc6uz3euFEyUlpuA0azt5uNhnmrUiCaAyUg==" />
之前按照后端的邏輯分析_nosec_session 的值 經(jīng)過(guò)解密以及各種xx手法得到 authenticity_token 的值,然后順帶著 username 和 password post就行了,老是用后端的思維思考問(wèn)題,過(guò)不得最近走路都走不好了。所以來(lái),直接在頁(yè)面中抓取已經(jīng)生成的 authenticity_token 的值,然后 順著 POST 過(guò)去就好了啊。
使用 requests 庫(kù) 的 Session()
方法,確實(shí)很好用,比早期直接拿 cookielib 就干方便多了。
代碼
類(lèi)XXX 的 login 方法用來(lái)模擬登錄,就貼出這部分登錄的代碼好了。
class XXX: def login(self): r = self.s.get('https://nosec.org/users/sign_in') html = r.text p1 = re.compile(r'city_token" value="(.*?)"') res = re.search(p1,html) authenticity_token = str(res.group(1)) print 'authenticity_token:',authenticity_token # print 'cookies',self.s.cookies # print s.cookies data = { 'authenticity_token':authenticity_token, 'user[login]':'xxxxx', 'user[password]':'xxxxx' } r = self.s.post('https://nosec.org/users/sign_in',data=data) # print r.headers # print r.request.headers # print self.s.cookies print '[*] OK!' return True
調(diào)用了 login 方法后 下次直接用self.s.get()
請(qǐng)求網(wǎng)頁(yè)就會(huì)帶著 cookie 啦。
之前被思路坑了一次,被筆誤也坑了一次(https 寫(xiě)成 http),導(dǎo)致我抓狂了好久才發(fā)現(xiàn)這個(gè) “BUG” = =、所以還得多謝 代碼,提高排 Bug 的效率 2333!
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
分享5個(gè)python提速技巧,速度瞬間提上來(lái)了
這篇文章主要給大家分享的是5個(gè)python提速技巧,工作或者學(xué)習(xí)的過(guò)程中難免會(huì)遇到卡頓問(wèn)題,下面的提速技巧具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-01-01python datetime時(shí)間格式的相互轉(zhuǎn)換問(wèn)題
這篇文章主要介紹了python datetime時(shí)間格式的相互轉(zhuǎn)換問(wèn)題,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06python 用opencv實(shí)現(xiàn)霍夫線變換
這篇文章主要介紹了python 如何用opencv實(shí)現(xiàn)霍夫線變換,幫助大家更好的理解和使用python處理圖片,感興趣的朋友可以了解下2020-11-11Python之lambda匿名函數(shù)及map和filter的用法
今天小編就為大家分享一篇關(guān)于Python之lambda匿名函數(shù)及map和filter的用法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03Python制作腳本幫女朋友搶購(gòu)清空購(gòu)物車(chē)
這篇文章主要介紹了Python制作的搶購(gòu)清空購(gòu)物車(chē)的腳本,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08python鏈接oracle數(shù)據(jù)庫(kù)以及數(shù)據(jù)庫(kù)的增刪改查實(shí)例
下面小編就為大家分享一篇python鏈接oracle數(shù)據(jù)庫(kù)以及數(shù)據(jù)庫(kù)的增刪改查實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01python調(diào)用pyaudio使用麥克風(fēng)錄制wav聲音文件的教程
這篇文章主要介紹了python調(diào)用pyaudio使用麥克風(fēng)錄制wav聲音文件的教程,詳細(xì)的給大家介紹了pyaudio庫(kù)的安裝與使用,需要的朋友可以參考下2019-06-06Python圖像處理之使用OpenCV檢測(cè)對(duì)象顏色
OpenCV顏色檢測(cè)只是一個(gè)起點(diǎn),最終目標(biāo)是最終使用Python?3代碼在視頻流幀中定位彩色元素位置,下面這篇文章主要給大家介紹了關(guān)于Python圖像處理之使用OpenCV檢測(cè)對(duì)象顏色的相關(guān)資料,需要的朋友可以參考下2022-12-12教你快速上手Selenium爬蟲(chóng),萬(wàn)物皆可爬
這篇文章主要介紹了教你如何快速上手Selenium,文中附含詳細(xì)示例代碼,包含基本使用以及操作步驟,有需要的朋友可以參考下,希望大家多多討論交流2021-08-08