python學習,使用requests庫來模擬登錄github,post請求。


這次我們要模擬登錄的頁面是

https://github.com/login

首先我們先嘗試着登陸一遍分析一下請求,

打開開發者工具下的network選項,

可以很清楚的看到這個會話session,而且是post請求,這多半是我們剛才登錄是所發出去的請求,我們往下拉查看form data

 

這里要注意,這個authenticity_token的值該怎么獲取,我們從網頁的源代碼中查找這個關鍵字,

發現這個值就在頁面中,而且每次刷新之后這個value總是會不斷地變化,好,分析完畢后,我們開始構建代碼

 1 import requests
 2 from bs4 import BeautifulSoup
 3 import time
 4 #自己寫的,模塊化一哈,舒服一哈,2019.5.6  22.22
 5 #模擬登陸練習,登錄github 
 6 class login(object):
 7     def __init__(self):
 8         self.headers={
 9                     'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.131 Safari/537.36'
10                 }
11         self.first_url='https://github.com/login'
12         self.second_url='https://github.com/session'
13         self.test_url='https://github.com/?tab=stars' #可以設置成你的個人主頁url
14         self.session=requests.Session()
15     def get_log(self):#這個方法是把token信息解析找到后傳遞
16         html=requests.get(url=self.first_url,headers=self.headers)
17         soup=BeautifulSoup(html.text,'lxml')
18         tokens=soup.find_all('input',type="hidden")[1]
19         at=tokens.attrs['value']
20         return at
21     def post_log(self,login,password):
       #這是要提交的表單
22 data={ 23 'commit':'Sign in', 24 'utf8':'', 25 'authenticity_token':self.get_log(), 26 'login':login, 27 'password':password, 28 'webauthn-support':' supported' 29 } 30 res=self.session.post(url=self.second_url,data=data,headers=self.headers) 31 self.test_func() 32 def test_func(self): #這個方法用來模擬登陸后請求我們的個人主頁,然后把源碼保存到文件里,以此來確定是否模擬登錄成功。 33 res2=self.session.get(url=self.test_url,headers=self.headers) 34 with open('gitstar.html','wb') as f: 35 f.write(res2.content) 36 if __name__=='__main__': 37 jessus=login() 38 jessus.post_log('你的用戶名','你的密碼')

運行一下,我們把保存的html文件打開

成功了,確實是我們的github主頁!

希望能給你提供思路,主要是requests post 請求,還有維持一個會話session很重要,如果你覺得文章還不錯,點個贊吧,謝謝!

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM