爬蟲微博模擬登陸-從移動端到PC端

爬蟲登陸微博辛燥,相信是諸多爬蟲愛好者必須跨過得一道坎盈厘。這不,這幾天我也在研究如何能夠快速而簡潔得實現(xiàn)登陸功能盗胀。
當然艘蹋,前期工作一定要做好,我先google + 百度了一把市面上的微博登陸教程票灰,發(fā)現(xiàn)基本上都是PC端的base64加密用戶名女阀,然后RSA加密拼接關(guān)鍵信息咱娶,最后組合成POST的from data 進行登陸。

擺在我面前的有兩條路强品,一條走PC端膘侮,一條走移動端。鑒于PC端已經(jīng)有詳盡教程的榛,此時琼了,我決定走一走移動端的路子》蛏危基于以往經(jīng)驗雕薪,任何網(wǎng)站如果有移動端,那一定是非常容易進行爬取的晓淀。果不其然所袁,移動端的微博登陸比我想象得還要簡單,一個簡單的POST即可搞定凶掰。

與此同時燥爷,在抓包的過程中,我亦發(fā)現(xiàn)懦窘,微博在移動端登陸以后前翎,會先訪問3個cross domain的網(wǎng)址來設(shè)置cookie。此刻畅涂,請大家注意港华,經(jīng)過這三個cross domain的設(shè)置后,我們居然可以直接以登陸狀態(tài)訪問PC端午衰。即在技術(shù)上以移動端作為翹板立宜,完美避開PC端復雜的校驗和加密。

曲線救國臊岸,古之人誠不我欺也!
Talk is cheap. Show me the code橙数。

#-*- coding=utf-8
from requests import Session
import json

def formatUrl(urldict):
    for key,value in urldict.items():
        urldict[key]=value.replace("\\",'')

headers={'User-Agent':'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36',
         'Referer':'https://passport.weibo.cn/signin/login?entry=mweibo'}

cookies={'_s_tentry':'news.ifeng.com',
        'UOR':'news.ifeng.com,widget.weibo.com,tech.ifeng.com'}

url='https://passport.weibo.cn/sso/login'

username=input('pls input weibo ID: ')
pwd =input('pls input weibo password: ')


fromdata={'username':username,'password':pwd,
        'savestate':'1','r':None,'ec':'0','pagerefer':None,
        'entry':'mweibo','wentry':None,'loginfrom':None,
        'client_id':None,'code':None,'qq':None,'mainpageflag':'1',
        'hff':None,'hfp':None}

with Session() as s:
    s.headers.update(headers)
    resp = s.post(url,data=fromdata)
    cross_domain_list = json.loads(resp.text)['data']['crossdomainlist']
    formatUrl(cross_domain_list)
    s.get(cross_domain_list['weibo.com'],cookies=cookies)
    #通過cross_domain 獲取PC端的登陸狀態(tài),此時可以以登錄狀態(tài)直接訪問PC端的頁面扇单,從而繞過諸多加密校驗
    s.get(cross_domain_list['sina.com.cn'])
    s.get(cross_domain_list['weibo.cn'])
    s.headers.update({'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8'})
    resp=s.get('https://weibo.com/')
    with open('webo.html','wb') as f:
        f.write(resp.content)

我宣布:微博的世界商模, 爬蟲大軍來啦!
注:如果需要鍛煉JS解析能力蜘澜,建議還是走PC端模擬登陸施流。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市鄙信,隨后出現(xiàn)的幾起案子瞪醋,更是在濱河造成了極大的恐慌,老刑警劉巖装诡,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件银受,死亡現(xiàn)場離奇詭異践盼,居然都是意外死亡,警方通過查閱死者的電腦和手機宾巍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門咕幻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人顶霞,你說我怎么就攤上這事肄程。” “怎么了选浑?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵蓝厌,是天一觀的道長。 經(jīng)常有香客問我古徒,道長拓提,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任隧膘,我火速辦了婚禮代态,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘舀寓。我一直安慰自己胆数,他們只是感情好,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布互墓。 她就那樣靜靜地躺著,像睡著了一般蒋搜。 火紅的嫁衣襯著肌膚如雪篡撵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天豆挽,我揣著相機與錄音育谬,去河邊找鬼。 笑死帮哈,一個胖子當著我的面吹牛膛檀,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播娘侍,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼咖刃,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了憾筏?” 一聲冷哼從身側(cè)響起嚎杨,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎氧腰,沒想到半個月后枫浙,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體刨肃,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年箩帚,在試婚紗的時候發(fā)現(xiàn)自己被綠了真友。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡紧帕,死狀恐怖锻狗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情焕参,我是刑警寧澤轻纪,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站叠纷,受9級特大地震影響刻帚,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜涩嚣,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一崇众、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧航厚,春花似錦顷歌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至麻顶,卻和暖如春赦抖,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背辅肾。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工队萤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人矫钓。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓要尔,卻偏偏與公主長得像,于是被迫代替她去往敵國和親新娜。 傳聞我的和親對象是個殘疾皇子赵辕,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內(nèi)容