快手扫码登陆

该博客详细介绍了如何使用Python实现快手扫码登录的过程,包括二维码生成、状态检测、登录验证和回调接口的调用。代码中包含了请求的完整流程,并提供了错误处理机制。用户需手动输入确认已扫码后,程序会继续执行登录接口并打印登录结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

快手扫码登陆

1.二维码生成接口:

https://id.kuaishou.com/rest/c/infra/ks/qr/start

在这里插入图片描述

响应值imageData为base64编码的二维码图片

在这里插入图片描述

2.检测过期状态

https://id.kuaishou.com/rest/c/infra/ks/qr/scanResult

3.效验Login

https://id.kuaishou.com/rest/c/infra/ks/qr/acceptResult
在这里插入图片描述

4.回调登陆接口:

https://id.kuaishou.com/pass/kuaishou/login/qr/callback

在这里插入图片描述

5.上代码:

# -*- coding: utf-8 -*-
# @Author  : Codeooo
# @Time    : 2021/11/15




import base64
import requests

from requests import RequestException


class KsLogin:

    session = requests.Session()

    def __init__(self):

        self.headers = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:90.0) Gecko/20100101 Firefox/80.0',
            'Accept': '*/*',
            'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2',
            'Referer': 'https://www.kuaishou.com/',
            'Content-type': 'application/x-www-form-urlencoded',
            'Origin': 'https://www.kuaishou.com',
            'Connection': 'keep-alive',
            'Sec-Fetch-Dest': 'empty',
            'Sec-Fetch-Mode': 'cors',
            'Sec-Fetch-Site': 'same-site',
            'Pragma': 'no-cache',
            'Cache-Control': 'no-cache',
        }



    def postRequests(self, url: str, data) -> str:

        for _ in range(5):
            try:
                res = self.session.post(
                    url=url,
                    headers=self.headers,
                    data=data,
                    proxies=self.proxies,
                    timeout=5
                )
            except RequestException:
                # self.proxies = rodmoProxy()
                # TODO 请求抛错未处理
                pass
                # time.sleep(random.randint(1, 3))
            else:
                return res.json()

    def authToken(self, token):

        authTokenUrl = f'https://www.kuaishou.com/rest/infra/sts?authToken={token}&sid=kuaishou.server.web'
        print("=====authTokenUrl=====:", authTokenUrl)

        for _ in range(5):
            try:
                res = self.session.get(
                    url=authTokenUrl,
                    headers=self.headers,
                    proxies=self.proxies,
                    timeout=5
                )
            except RequestException:
                pass
                # self.proxies = rodmoProxy()
                # TODO 请求抛错未处理
                # time.sleep(random.randint(1, 3))
            else:
                print(res.cookies.get_dict())
                html = res.json()
                return html
        return

    def main(self):


        """proxy测试"""
        # self.proxies = rodmoProxy()
        self.proxies = None


        # 二维码
        qrCode = self.postRequests('https://id.kuaishou.com/rest/c/infra/ks/qr/start',  {"sid": 'kuaishou.server.web'})
        print("=====生成二维码=====:",qrCode)
        qrLoginToken = qrCode.get("qrLoginToken")
        qrLoginSignature = qrCode.get("qrLoginSignature")

        with open('qrCode.jpg', 'wb') as file:
            file.write(base64.b64decode(qrCode.get("imageData")))

        input("请扫码二维码:Y/N")


        data_accept = {
            'qrLoginToken': qrLoginToken,
            'qrLoginSignature': qrLoginSignature,
            'sid': 'kuaishou.server.web'
        }


        # 效验Login
        acceptResult = self.postRequests('https://id.kuaishou.com/rest/c/infra/ks/qr/acceptResult',  data_accept)
        qrToken = acceptResult.get("qrToken")


        # # 检测过期状态
        # scanResult = self.postRequests('https://id.kuaishou.com/rest/c/infra/ks/qr/scanResult', data_accept)
        # print("=====检测过期状态=====:",scanResult)

        at_data = {
            'qrToken': qrToken,
            'sid': 'kuaishou.server.web'
        }


        #登陆接口
        result = self.postRequests('https://id.kuaishou.com/pass/kuaishou/login/qr/callback', at_data)

        print(result)




if __name__ == '__main__':


    """主逻辑"""
    spider = KsLogin()
    try:
        spider.main()
    except TimeoutError:
        # todo 未处理
        raise ValueError




评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Codeooo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值