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爬取雪中悍刀行弹幕分析并可视化详程

    下面是“Python爬取雪中悍刀行弹幕分析并可视化详程”的完整攻略。 1. 网页爬取 我们可以使用Python中的requests库来下载网页源代码,并使用beautifulsoup库来解析网页。 import requests from bs4 import BeautifulSoup url = ‘https://www.bilibili.com/vid…

    python 2023年5月20日
    00
  • Python正则表达式匹配中文用法示例

    Python正则表达式匹配中文用法示例 在Python中,我们可以使用正则表达式进行中文字符串的匹配和替换。在正表达式中,中文字符使用Unicode编码进行匹配。本攻略将详细讲解如何使用Python正则表达式匹配中文字符串,包括如何使用Unicode码进行匹配、如何使用re模块进行匹配。 使用Unicode编码进行匹配 在Python中,我们可以使用Unic…

    python 2023年5月14日
    00
  • Python cookbook(数据结构与算法)找到最大或最小的N个元素实现方法示例

    Python Cookbook 中提供了多种查找最大或最小的 N 个元素的实现方法示例,下面我们就来详细讲解其中两个实现方法。 heapq.nlargest 和 heapq.nsmallest 示例 heapq 模块是 Python 中用于实现堆排序算法的模块,我们可以使用该模块中的 nlargest 和 nsmallest 函数来实现找到序列中最大或最小的…

    python 2023年5月14日
    00
  • 详解Python向元组添加元素

    针对该问题,我将给出一个完整的Python程序向元组添加元素的方法攻略: 1. 概述 在 Python 中,元组是一种不可变序列,即元组一旦被创建就不能更改它的内容。这表明在原有的元组上新增元素是不允许的,但是可以通过创建一个新元组,并在其中包含既有的元组和新元素来完成这一操作。 2. 如何向元组添加元素 2.1 通过 + 运算符 一种向元组添加元素的方式是…

    python-answer 2023年3月25日
    00
  • Python不同格式打印九九乘法表示例

    下面是Python不同格式打印九九乘法表的攻略。 示例代码 # 示例代码1: 简单循环嵌套实现 for i in range(1, 10): for j in range(1, i + 1): print(f'{j} × {i} = {i*j}\t’, end=”) print() # 示例代码2:使用字符串模板实现 template = ‘{0} × {…

    python 2023年6月5日
    00
  • Python入门篇之文件

    Python入门篇之文件 在Python中,文件是操作和处理数据不可或缺的一部分。本篇文章将介绍Python中文件的基本操作,包括文件的打开、读取、写入和关闭等。 打开文件 在Python中,我们使用open()函数来打开一个文件。open()函数接收两个参数:文件名和模式(可选)。常见的模式包括’r’(读取模式,默认),’w’(写入模式)、’a’(追加模式…

    python 2023年6月2日
    00
  • 跟老齐学Python之list和str比较

    跟老齐学Python之list和str比较 在Python中,list和str是两种常见的数据类型。虽然它们都可以存储多个元素,但是它们之间还是有很大区别的。本文将详细讲解list和str的比较,包括定义、操作、转换等方面的内容,并给出两个示例说明。 定义 list和str的定义方式不同。list使用方括号[]来定义,元素之间用逗号隔开。例如: my_lis…

    python 2023年5月13日
    00
  • python批量读取txt文件为DataFrame的方法

    下面是“python批量读取txt文件为DataFrame的方法”的完整攻略,包括以下步骤: 步骤一:准备数据 首先需要获得一些示例数据,这些示例数据应该存在于多个.txt文件中。这些文件应该具有相同的格式,可以包含标头和数据,以制表符或其他分隔符分隔。 步骤二:导入必要的库 在使用本方法之前,需要导入pandas库。可以使用以下命令导入pandas: im…

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