Python3.2模拟实现webqq登录

下面是“Python3.2模拟实现webqq登录”的完整攻略,主要分为以下几步:

准备工作

  1. 安装Python 3.2及以上版本,并配置好环境变量。

  2. 安装requests模块,这个模块是用来发送HTTP请求的,可以通过pip安装:

pip install requests

  1. 获取WebQQ登录所需的一些参数,主要有以下几个:

  2. ptwebqq:通过访问https://s.web2.qq.com,查看Cookie中名为ptwebqq的值。该参数是登录WebQQ时所需的主要参数。

  3. g_login_sig:通过访问https://d1.web2.qq.com,查看Cookie中名为g_login_sig的值。该参数是登录WebQQ时所需的主要参数。

  4. ptqrtoken:通过访问https://ptlogin2.qq.com/check,查看返回的含有ptqrtoken参数的url。该参数是处理二维码时所需的主要参数。

  5. session:通过访问https://s.web2.qq.com,查看Cookie中名为skey的值。该参数是登录WebQQ后所需的主要参数。

  6. vfwebqq:通过访问https://s.web2.qq.com,查看返回的JSON数据中含有vfwebqq参数的值。该参数是处理消息时所需的主要参数。

实现代码

以下是Python代码实现WebQQ登录过程的完整攻略:

import time
import random
import hashlib
import requests


def get_login_url(qr_code_url):
    """
    处理二维码,获取登录后的URL
    """
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
    }
    response = requests.get(qr_code_url, headers=headers)
    ptqrtoken = response.cookies.get('qrsig')
    print('请扫描二维码登录...')
    while True:
        time.sleep(1)
        check_url = 'https://ssl.ptlogin2.qq.com/check?ptqrtoken={}&webqq_type=10&remember_uin=1&login2qq=1&aid=501004106&u1=https%3A%2F%2Fqq.com%2F&ptredirect=0&h=1&from_ui=1&pttype=1&dumy=&fp=loginerroralert&action=0-0-{}'.format(ptqrtoken, int(time.time()*1000))
        check_response = requests.get(check_url, headers=headers)
        if '登录成功' in check_response.text:
            return check_response.text.split('\'')[1]


def get_login_cookies(qr_code_url):
    """
    获取登录后的Cookie
    """
    login_url = get_login_url(qr_code_url)
    ptcz = ''
    uin = ''
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
        'Referer': 'https://xui.ptlogin2.qq.com/cgi-bin/xlogin?appid=501004106&daid=1&pt_no_auth=1&s_url=https://web2.qq.com/proxy.html&style=40&low_login=0&proxy_url=https://web2.qq.com/proxy.html&hide_title_bar=1&hide_close_icon=1&no_verifyimg=1&no_qrcode=0&self_regurl=https://ui.ptlogin2.qq.com/cgi-bin/login?proxy_url=https://web2.qq.com/proxy.html&pt_i_from=&ptlang=2052&ptredirect=0&aid=501004106&login_sig=&pt_uistyle=40&pt_jstoken=401524137',
    }
    response = requests.get(login_url, headers=headers)
    for cookie in response.cookies:
        if cookie.name == 'ptcz':
            ptcz = cookie.value
        elif cookie.name == 'uin':
            uin = cookie.value
    return {
        'ptwebqq': response.cookies.get('ptwebqq'),
        'pgv_pvid': '5878843884',
        'pgv_info': 'ssid=s6840495612',
        'skey': response.cookies.get('skey'),
        'p_uin': uin,
        'p_skey': response.cookies.get('p_skey'),
        'ptcz': ptcz,
        'qrsig': '',  # 这个字段可以不用设置,因为已经获取到了。
        'uin': uin,
    }


def get_vfwebqq(cookies):
    """
    获取vfwebqq参数
    """
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
        'Referer': 'https://s.web2.qq.com/proxy.html?v=20130916001&callback=1&id=1',
    }
    url = 'https://s.web2.qq.com/api/getvfwebqq?ptwebqq={}&clientid=53999199&psessionid=&t={}'.format(cookies['ptwebqq'], int(time.time()))
    response = requests.get(url, headers=headers, cookies=cookies)
    return response.json()['result']['vfwebqq']


def get_psessionid_and_uid(cookies):
    """
    获取psessionid和uid参数
    """
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
        'Referer': 'https://d1.web2.qq.com/cfproxy.html?v=20151105001&callback=1',
    }
    url = 'https://d1.web2.qq.com/channel/login2'
    r = str(int(random.random()*100000000))
    login_data = {
        'r': r,
        'pt2gguin': cookies['uin'],
        'ptwebqq': cookies['ptwebqq'],
        'clientid': 53999199,
        'psessionid': '',
        'status': 'online',
    }
    psessionid_header = {
        'Referer': 'https://d1.web2.qq.com/proxy.html?v=20151105001&callback=1&id=2',
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
        'Origin': 'https://d1.web2.qq.com',
    }
    response = requests.post(url, headers=headers, cookies=cookies, json=login_data)
    psessionid = response.json()['result']['psessionid']
    uid = response.json()['result']['uin']
    return psessionid, uid


def get_group_list(psessionid, cookies):
    """
    获取群组列表
    """
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
        'Referer': 'https://d1.web2.qq.com/cfproxy.html?v=20151105001&callback=1',
    }
    url = 'https://s.web2.qq.com/api/get_group_name_list_mask2'
    r = str(int(random.random()*100000000))
    data = {
        'r': r,
        'vfwebqq': get_vfwebqq(cookies),
        'hash': hashlib.md5((str(cookies['p_uin'])+psessionid).encode('utf-8')).hexdigest(),
    }
    response = requests.post(url, headers=headers, cookies=cookies, json=data)
    return response.json()


if __name__ == '__main__':
    qr_code_url = 'https://ptlogin2.qq.com/ptqrshow?appid=501004106&e=2&l=M&s=3&d=72&v=4&t=0.5257469508827072'
    cookies = get_login_cookies(qr_code_url)
    psessionid, uid = get_psessionid_and_uid(cookies)
    group_list = get_group_list(psessionid, cookies)
    print(group_list)

示例说明

为了更好的说明上述程序,这里给出两个示例:

示例一

输入以下代码即可运行第一个示例:

if __name__ == '__main__':
    qr_code_url = 'https://ptlogin2.qq.com/ptqrshow?appid=501004106&e=2&l=M&s=3&d=72&v=4&t=0.5257469508827072'
    cookies = get_login_cookies(qr_code_url)
    psessionid, uid = get_psessionid_and_uid(cookies)
    group_list = get_group_list(psessionid, cookies)
    print(group_list)

运行该程序后,会输出WebQQ所有的群组名称及其gid和code值。示例输出如下:

{'retcode': 0, 'result': {'gnamelist': [{'flag': 16778241, 'name': '某某联盟(006)', 'gid': 1929842108, 'code': 530648501, 'owner': 835698566, 'createtime': 1479142131, 'level': 5}, {'flag': 81, 'name': '客户群', 'gid': 875150207, 'code': 3084357681, 'owne...

示例二

下面是另一个示例,该示例演示如何发送WebQQ消息。输入以下代码即可运行:

import json


def send_message(qq_number, message_content, psessionid, cookies):
    """
    发送WebQQ消息
    """
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
        'Referer': 'https://d1.web2.qq.com/cfproxy.html?v=20151105001&callback=1&id=2',
    }
    url = 'https://d1.web2.qq.com/channel/send_buddy_msg2'
    r = str(int(random.random()*100000000))
    data = {
        'r': r,
        'to': qq_number,
        'face': 0,
        'content': json.dumps([message_content, ['font', {'name': '宋体', 'size': '10', 'style': [0, 0, 0], 'color': '000000'}]]),
        'msg_id': int(time.time()*1000),
        'clientid': 53999199,
        'psessionid': psessionid,
    }
    response = requests.post(url, headers=headers, cookies=cookies, json=data)
    return response.json()


if __name__ == '__main__':
    qq_number = 12345  # 这里填入测试对象的QQ号码。
    message_content = 'Hello, World!'  # 这里填入消息内容。
    qr_code_url = 'https://ptlogin2.qq.com/ptqrshow?appid=501004106&e=2&l=M&s=3&d=72&v=4&t=0.5257469508827072'
    cookies = get_login_cookies(qr_code_url)
    psessionid, uid = get_psessionid_and_uid(cookies)
    send_message(qq_number, message_content, psessionid, cookies)

运行该程序后,会自动发送消息给指定的WebQQ用户。注意,此处需要手动输入测试用户的QQ号码,以及要发送的消息内容。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Python3.2模拟实现webqq登录 - Python技术站

(0)
上一篇 2023年6月3日
下一篇 2023年6月3日

相关文章

  • python将三维数组展开成二维数组的实现

    要将一个三维数组展开成二维数组,我们需要把每个二维数组在第一个维度上拼接成一个大二维数组。可以使用NumPy库来实现这个功能。 下面是Python将三维数组展开成二维数组的步骤: 1. 导入NumPy库 要使用NumPy将三维数组展开成二维数组,需要先导入NumPy库。可以使用以下代码导入: import numpy as np 2. 定义三维数组 在使用N…

    python 2023年6月5日
    00
  • php与python实现的线程池多线程爬虫功能示例

    首先需要了解什么是线程池和多线程爬虫。 线程池是指提前创建好一定数量的线程,等待需要执行任务的时候,将任务分配给已经创建的线程执行,避免了频繁创建和销毁线程的开销,提高了程序的运行效率。 多线程爬虫是指通过创建多个线程,同时抓取多个网页,加快抓取的速度。 下面是实现“php与python实现的线程池多线程爬虫功能”的攻略: 准备工作 为了完成线程池多线程爬虫…

    python 2023年5月19日
    00
  • Python函数设置默认参数

    在Python中,可以为函数参数指定默认值,这些参数被称为默认参数。如果调用函数时没有传递这些参数,则使用默认值。 默认参数可以在定义函数时指定,例如: def greet(name, greeting="Hello"): print(greeting, name) 在上面的示例中,greeting参数具有默认值"Hello&q…

    2023年2月20日
    00
  • Python 从文件中读取字符串,保留要打印的变量

    【问题标题】:Python read strings from file, preserving variables to be printedPython 从文件中读取字符串,保留要打印的变量 【发布时间】:2023-04-04 02:46:02 【问题描述】: 我正在制作一个 Python 脚本,它将从列表中随机选择一个响应。 为了填充这个列表,我想从文…

    Python开发 2023年4月6日
    00
  • Python文本处理简单易懂方法解析

    Python文本处理是一种处理文本数据的技术,可以用于文本分析、文本挖掘、自然语言处理等领域。以下是Python文本处理简单易懂方法解析的详细攻略: 分词 分词是将文本分割成单词或词组的过程。可以使用Python的nltk库进行分词。以下是一个分词的示例: import nltk text = "This is an example sentenc…

    python 2023年5月14日
    00
  • Python的None和C++的NULL用法解读

    下面是我对于Python的None和C++的NULL用法解读的攻略。 Python的None和C++的NULL用法解读 Python的None 概述 Python中的None是一个特殊的数据类型,代表空值,相当于其他编程语言中的NULL、nil、undefined等。None不等同于空字符串、空列表、空字典等,它是一个唯一的对象,有自己的类型。 用法 在Py…

    python 2023年5月13日
    00
  • 举例讲解Python中的迭代器、生成器与列表解析用法

    接下来我将详细讲解“举例讲解Python中的迭代器、生成器与列表解析用法”的完整攻略。 什么是迭代器? 在了解迭代器之前,先了解一下可迭代对象。可迭代对象是指序列类型的数据(如list、tuple等),以及实现了__iter__方法的对象。而迭代器是一种特殊的可迭代对象,它可以实现惰性生成数据,即在需要获取下一个元素时才生成,从而节省内存。 Python中的…

    python 2023年5月13日
    00
  • 如何在 Redis 中实现布隆过滤器?

    以下是详细讲解如何在 Redis 中实现布隆过滤器的完整使用攻略。 Redis 布隆过滤器简介 Redis 布隆过滤器是一种常用的数据结构,可以用于快速判断一个元素是否存在于集合中。Redis 布隆过滤器的特点如下: Redis 布隆过滤器是基于的位图实现的。 Redis 布隆过滤器可以快速判断一个元素是否存在于集合中。 Redis 布隆过滤器可以通过调整参…

    python 2023年5月12日
    00
合作推广
合作推广
分享本页
返回顶部