笔记-模拟登录github

1.      模拟登录github

1.1.    环境准备

安装/升级requests 2.20.0

pip install --upgrade requests

pip show requests

1.2.    分析登录过程及模拟

  1. 在chome打开github.com/login,按f12,选中network>preserver log(表示持续日志),进入调试模式。
  2. 找到登录页面:

检查发现login页面输入内容回车后会跳转页面,实际上是由github.com/session页面接收数据并完成登录。

  1. 构造请求包:

接下来就是构造请求了,包括headers和form data两部分;

头部构造已经很熟悉了,主要是注意不要漏掉一些字段,包括referer,Origin等,实际上在session页面的post头部中要包含有login页面返回的cookie,但Session会自动完成这个过程,所以不需要手动指定了。

字段全一些可以降低被反爬的机率。

form data分为两部分,固定部分无所谓,但有一个字段authenticity_token是由login页面返回,通过正则找到它即可。

  1. 发送请求,得到应答;

登录成功后会自动重定向到首页,此时已经做到了session 的状态保持。

  1. 验证登录成功。

1.3.    问题

在post登录请求后总是返回422:

错误码代表请求格式正确,但含有语义错误,无法响应。

检查发现authenticity_token拼写错,改正后正常。

1.4.    代码实现

#coding:utf-8

'''

模拟登录github

'''

import copy

import requests

from lxml import etree

class Login():

def __init__(self):

self.headers = {

'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',

'Accept-Encoding':'gzip, deflate, br',

'Accept-Language':'zh-CN,zh;q=0.9',

'Cache-Control':'max-age=0',

'Connection':'keep-alive',

'Host':'github.com',

'Upgrade-Insecure-Requests':'1',

'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'

}

self.login_url = 'https://github.com/login'

self.post_url = 'https://github.com/session'

self.profileUrl = 'https://github.com/settings/profile'

self.session = requests.Session()

def _token(self):

'''

parse for token.

'''

response = self.session.get(self.login_url, headers=self.headers)

selector = etree.HTML(response.text)

token = selector.xpath('//div//input[2]/@value')[0]

return token

def login(self, username, password):

post_data = {

'commit':'Sign in',

'utf-8':'✓',

'authenticity_token':self._token(),

'login':username,

'password':password

}

header_temp = copy.copy(headers)

header_add = {'Referer':r.url,'Origin':'https://github.com'}

header_temp.update(header_add)

response = self.session.post(self.post_url, headers=header_temp, data= post_data)

def islogin(self):

‘’’登录成功验证。’’’

try:

response = self.session.get(self.profileUrl, headers=self.headers)

except:

print('get page failed!')

selector = etree.HTML(response.text)

flag = selector.xpath('//div[@class="column two-thirds"]/dl/dt/label/text()')

info = selector.xpath('//div[@class="column two-thirds"]/dl/dd/input/@value')

textarea = selector.xpath('//div[@class="column two-thirds"]/dl/dd/textarea/text()')

# 登陆成功返回来的个人设置信息

print(u'个人设置Profile标题: %s'%flag)

print(u'个人设置Profile内容: %s'%info)

print(u'个人设置Profile内容: %s'%textarea)

if __name__ == '__main__':

login = Login()

login.login(username='username’, password='password')

login.islogin()

笔记-爬虫-模拟登录github的更多相关文章

  1. Java豆瓣电影爬虫——模拟登录的前世今生与验证码的爱恨情仇

    前言 并不是所有的网站都能够敞开心扉让你看个透彻,它们总要给你出些难题让你觉得有些东西是来之不易的,往往,这也更加激发你的激情和斗志! 从<为了媳妇的一张号,我与百度医生杠上了>里就有网友 ...

  2. Java爬虫模拟登录——不给我毛概二的H某大学

    你的账号访问太频繁,请一分钟之后再试! 从大一开始 就用脚本在刷课 在专业课踢的只剩下一门C#的情况下 活活刷到一周的课 大二开始教务系统多了一个非常**的操作 退课池 and 访问频繁缓冲 难道,我 ...

  3. python学习,使用requests库来模拟登录github,post请求。

    这次我们要模拟登录的页面是 https://github.com/login 首先我们先尝试着登陆一遍分析一下请求, 打开开发者工具下的network选项, 可以很清楚的看到这个会话session,而 ...

  4. python爬虫模拟登录的图片验证码处理和会话维持

    目标网站:古诗文网 登录界面显示: 打开控制台工具,输入账号密码,在ALL栏目中进行抓包 数据如下: 登录请求的url和请求方式 登录所需参数 参数分析: __VIEWSTATE和__VIEWSTAT ...

  5. Java爬虫——模拟登录知乎

    登录界面,首先随意输入一个账号,登录查看发送表单的请求 可以发现请求是Post : https://www.zhihu.com/login/phone_num 发送的表单是 _xsrf: passwo ...

  6. python自动化之爬虫模拟登录

    http://selenium-python.readthedocs.io/locating-elements.html ####################################### ...

  7. php后台“爬虫”模拟登录第三方系统

    http://blog.csdn.net/liu_c_y/article/details/49956679 http://www.php100.com/html/webkaifa/PHP/PHPyin ...

  8. Python爬虫模拟登录带验证码网站

    问题分析: 1.爬取网站时经常会遇到需要登录的问题,这是就需要用到模拟登录的相关方法.python提供了强大的url库,想做到这个并不难.这里以登录学校教务系统为例,做一个简单的例子. 2.首先得明白 ...

  9. Scrapy模拟登录GitHub

    d: 进入D盘 scrapy startproject GitHub 创建项目 scrapy genspider github github.com 创建爬虫 编辑github.py: # -*- c ...

随机推荐

  1. 解决 MVC4 Code First 数据迁移 数据库发生更改导致调试失败解决方法(二)

    文章转载自:http://www.cnblogs.com/amoniyibeizi/p/4486617.html 前几天学MVC过程中,遇到更改Model类以后,运行程序就会出现数据已更改的问题导致调 ...

  2. Struts2_BBS2009小实战

    Struts2_BBS2009准备:链接: http://pan.baidu.com/s/1nvTZz9R 密码: 875a ext3.0_直接部署运行:链接: http://pan.baidu.co ...

  3. javascript:json对象和json字符串的相互转换

    json对象和字符串的相互转换 //使用json中的parser方法转换: var str='{"name":"fendouer", "age&quo ...

  4. element-ui打包的坑爹之处 !!!必看三遍!!!

    最近笔者打包element-ui出现如下问题: ERROR in static/js/0.4cad92088cb8dc6e7afd.js from UglifyJs Unexpected token: ...

  5. 屏蔽各类弹窗广告(WPS、智能云输入法)

    托盘中的广告“领取双11红包,最高1111元”的罪魁祸首是“智能云输入法” 广告在托盘中闪动: 结束SCSkinInst.exe后,托盘中的广告消失: 智能云输入法的安装路径可参考: C:\Progr ...

  6. Object-C 语法 字符串 数组 字典 和常用函数 学习笔记

    字符串 //取子字符串 NSString *str1=@"今天的猪肉真贵,200块一斤"; NSString *sub1=[str1 substringFromIndex:4]; ...

  7. 搭建TFTP服务器配置

    实验内容: TFTP是TCP/IP协议族中的一个用来在客户机与服务器之间进行简单文件传输的协议,提供不复杂,开销不大的文件传输服务.TFTP承载在UDP上,提供不可靠的数据传输服务,不提供存取授权与认 ...

  8. *205. Isomorphic Strings (string & map idea)

    Given two strings s and t, determine if they are isomorphic. Two strings are isomorphic if the chara ...

  9. Javascript作业—取字符串的第一个只出现一次的字母

    js作业 取字符串第一个只出现一次的字母 <script type='text/javascript'> //取a-z字符串中第一个只出现一次的字母 function firstUniqu ...

  10. 第32章 TIM—高级定时器—零死角玩转STM32-F429系列

    第32章     TIM—高级定时器 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fire ...