爬虫:模拟github登陆

根据崔庆才崔大大的又改了一下。

import requests
from lxml import etree


class Login(object):
    def __init__(self):
        self.headers = {
            'Referer': 'https://github.com/',
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36',
            'Host': 'github.com'
        }
        self.login_url = 'https://github.com/login'
        self.post_url = 'https://github.com/session'
        self.logined_url = 'https://github.com/settings/profile'
        self.session = requests.Session()

    def token(self):
        response = self.session.get(self.login_url, headers=self.headers)
        selector = etree.HTML(response.text)
        # print(response.text)
        # print((etree.tostring(selector)).decode('utf-8'))
        # 修改此处
        token = selector.xpath('//div[@id="login"]//input/@value')[0]
        # print(token)
        return token

    def login(self, email, password):
        post_data = {
             'commit': 'Sign in',
            'utf8': '✓',
            'authenticity_token': self.token(),
             'login': email,
             'password': password
        }

        response = self.session.post(self.post_url, data=post_data, headers=self.headers)
        if response.status_code == 200:
            # print(response.text)
            self.dynamics(response.text)

        response = self.session.get(self.logined_url, headers=self.headers)
        if response.status_code == 200:
            self.profile(response.text)

    def dynamics(self, html):
        selector = etree.HTML(html)
        # print((etree.tostring(selector)).decode('utf-8'))
        dynamics = selector.xpath('//div[contains(@class, "news")]//div[contains(@class, "alert")]')
        # 此处未有节点
        # print(dynamics)
        for item in dynamics:
            dynamic = ' '.join(item.xpath('.//div[@class="title"]//text()')).strip()
            # print('dynamic')
            print(dynamic)

    def profile(self, html):
        selector = etree.HTML(html)
        name = selector.xpath('//input[@id="user_profile_name"]/@value')[0]
        email = selector.xpath('//select[@id="user_profile_email"]/option[@value!=""]/text()')
        print(name, email)


if __name__ == "__main__":
    login = Login()
    login.login(email='1319144981@qq.com', password='***************')

运行结果

在这里插入图片描述

这个是requirements.txt

certifi==2020.6.20
chardet==3.0.4
cssselect==1.1.0
idna==2.10
lxml==4.5.2
PyMySQL==0.10.1
pyquery==1.4.1
redis==3.5.3
requests==2.24.0
urllib3==1.25.10

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值