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很重要,如果你觉得文章还不错,点个赞吧,谢谢!

 

posted @ 2019-05-08 17:14  死一样的痛过  阅读(1498)  评论(0编辑  收藏  举报