python介面自動化4-繞過驗證碼登入(cookie)

來源:互聯網
上載者:User

標籤:參數   ade   變數   工具   產生   完整   main   cat   bsp   

前言

有些登入的介面會有驗證碼:簡訊驗證碼,圖形驗證碼等,這種登入的話驗證碼參數可以從後台擷取的(或者查資料庫最直接)。

擷取不到也沒關係,可以通過添加cookie的方式繞過驗證碼。

一、抓登入cookie

1.登入後會產生一個已登入狀態的cookie,那麼只需要直接把這個值添加到cookies裡面就可以了。

2.可以先手動登入一次,然後抓取這個cookie,這裡就需要用抓包工具fiddler了

3.先開啟部落格園登入介面,手動輸入帳號和密碼(勾選下次自動登入)

4.開啟fiddler抓包工具,重新整理下登入首頁,就是登入前的cookie了

5.登入成功後,再查看cookie變化,發現多了兩組參數,多的這兩組參數就是我們想要的,copy出來,一會有用

 

二、cookie組成結構

1.用抓包工具fidller只能看到cookie的name和value兩個參數,實際上cookie還有其它參數

2.以下是一個完整的cookie組成結構

cookie ={u‘domain‘: u‘.cnblogs.com‘,
            u‘name‘: u‘.CNBlogsCookie‘,
            u‘value‘: u‘xxxx‘,
            u‘expiry‘: 1491887887,
            u‘path‘: u‘/‘,
            u‘httpOnly‘: True,
            u‘secure‘: False}

name:cookie的名稱

value:cookie對應的值,動態產生的

domain:伺服器網域名稱

expiry:Cookie有效終止日期

path:Path屬性定義了Web伺服器上哪些路徑下的頁面可擷取伺服器設定的Cookie

httpOnly:防指令碼攻擊

secure:在Cookie中標記該變數,表明只有當瀏覽器和Web Server之間的通訊協定為加密認證協議時,

瀏覽器才向伺服器提交相應的Cookie。當前這種協議只有一種,即為HTTPS。

 

三、添加cookie

1.往session裡面添加cookie可以用以下方式

2.set裡面參數按括弧裡面的參數格式

coo = requests.cookies.RequestsCookieJar()  

coo.set(‘cookie-name‘, ‘cookie-value‘, path=‘/‘, domain=‘.xxx.com‘)  

s.cookies.update(c) 

3.於是添加登入的cookie,把第一步fiddler抓到的內容填進去就可以了

c = requests.cookies.RequestsCookieJar()
c.set(‘.CNBlogsCookie‘, ‘xxx‘)
c.set(‘.Cnblogs.AspNetCore.Cookies‘,‘xxx‘)
s.cookies.update(c)
print(s.cookies)

4.(敲黑板!!!)由於近期部落格園的登入機制變了,這裡需要多加2個cookie參數

c.set(‘AlwaysCreateItemsAsActive‘,"True")
c.set(‘AdminCookieAlwaysExpandAdvanced‘,"True")

 

四、參考代碼

1.由於登入時候是多加2個cookie,我們可以先用get方法開啟登入首頁,擷取部分cookie

2.再把登入需要的cookie添加到session裡

3.添加成功後,隨便編輯本文和標題儲存到草稿箱

 1  # coding:utf-8 2 import requests 3  4 # 先開啟登入首頁,擷取部分cookie 5 url = "https://passport.cnblogs.com/user/signin" 6 headers = { 7             "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0" 8            }  # get方法其它加個ser-Agent就可以了 9 10 s = requests.session()11 r = s.get(url, headers=headers,verify=False)12 print s.cookies13 14 # 添加登入需要的兩個cookie15 c = requests.cookies.RequestsCookieJar()16 17 c.set(‘.CNBlogsCookie‘, ‘這裡是抓到的‘)  # 填上面抓包內容18 c.set(‘.Cnblogs.AspNetCore.Cookies‘,‘這裡是抓到的‘)  # 填上面抓包內容19 c.set(‘AlwaysCreateItemsAsActive‘,"True")20 c.set(‘AdminCookieAlwaysExpandAdvanced‘,"True")21 s.cookies.update(c)22 print s.cookies23 24 # 登入成功後儲存編輯內容25 r1 = s.get("https://i.cnblogs.com/EditPosts.aspx?opt=1", headers=headers, verify=False)26 27 # 儲存草稿箱28 url2= "https://i.cnblogs.com/EditPosts.aspx?opt=1"29 body = {"__VIEWSTATE": "",30         "__VIEWSTATEGENERATOR":"FE27D343",31         "Editor$Edit$txbTitle":"這是3111",32         "Editor$Edit$EditorBody":"<p>這裡111:http://www.cnblogs.com/yoyoketang/</p>",33         "Editor$Edit$Advanced$ckbPublished":"on",34         "Editor$Edit$Advanced$chkDisplayHomePage":"on",35         "Editor$Edit$Advanced$chkComments":"on",36         "Editor$Edit$Advanced$chkMainSyndication":"on",37         "Editor$Edit$Advanced$txbEntryName":"",38         "Editor$Edit$Advanced$txbExcerpt":"",39         "Editor$Edit$Advanced$tbEnryPassword":"",40         "Editor$Edit$lkbDraft":"存為草稿",41          }42 r2 = s.post(url2, data=body, verify=False)43 print r.content

 

python介面自動化4-繞過驗證碼登入(cookie)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.