[Python] Просмотр содержимого сообщений о выходе из WeChat

задняя часть Python WeChat API

Перед сном напишите статью об itchat.itchat — это модуль для WeChat на python.Он очень мощный и глупый в использовании.Вы гарантированно узнаете его, когда увидите.

Код в этой статье основан на Python.

Платформа для запуска кода — Alibaba Cloud ECS CentOS версии 6.5.

Вступительное отступление! ! !

Я супер шлюха, пока она в группе, в которой я состою, все монстры и монстры не хотят снимать новости! Эй Эй Эй!


1. модуль чата

Информация очень полная, поэтому больше не буду многословен, просто перейду сразу по ссылке:

Python реализует интерфейс WeChat (itchat)

Интерфейс WeChat python -- документация itchat

Проще говоря, itchat использует веб-версию WeChat, которая имитирует процесс входа на веб-страницу с помощью WeChat, поэтому то, что можно сделать в веб-версии WeChat, itchat может делать, за исключением моментов, потому что моментов еще нет. открыл веб-интерфейс.

2. Принцип просмотра сообщений о выводе средств WeChat

Кэшируйте каждое сообщение, а затем отправьте вам уже подготовленное сообщение, когда обнаружит, что сообщение было отозвано.

Несколько звонков:

  1. msg_register регистрирует типы сообщений, которые необходимо отслеживать, а объектами операций следующих функций являются только что зарегистрированные типы сообщений, которые могут быть текстом, изображениями, официальными сообщениями учетной записи и групповыми сообщениями. . .
  2. "isGroupChat=True" в регистрации указывает на то, что групповое сообщение зарегистрировано, то есть отзыв группового сообщения некуда спрятать. Конечно, следующая функция предназначена для групповых сообщений.
  3. После обнаружения отзыва сообщения, вот, itchat.send_msg(msg_body, toUserName='filehelper'), скрипт отправляет сообщение файловому хелперу, конечно, можно и самому себе отправить (имя пользователя это поле не нужно ), но я в основном различаю сообщения опровержения.
  4. enableCmdQR=True в itchat.auto_login(enableCmdQR=True, hotReload=True) при входе означает генерировать QR-код в символьном формате, если этот параметр не добавить, будет генерироваться QR-код в формате изображения, который нельзя открыть в CentOS.Поэтому этот домен обязательно должен быть, второй hotReload, как следует из названия, заключается в том, что после того, как вы один раз войдете в систему, просканировав код мобильным телефоном, при следующем запуске скрипта вам не нужно сканировать код и войдите в систему напрямую. Конечно, предполагается, что вы не вошли в систему на других платформах.

3. Исходный код

# coding:utf-8
import itchat
from itchat.content import TEXT
from itchat.content import *
import sys
import time
import re

reload(sys)
sys.setdefaultencoding('utf8')
import os

msg_information = {}
face_bug=None  #针对表情包的内容


@itchat.msg_register([TEXT, PICTURE, FRIENDS, CARD, MAP, SHARING, RECORDING, ATTACHMENT, VIDEO],isFriendChat=True, isMpChat=True)
def handle_receive_msg(msg):
    global face_bug
    msg_time_rec = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())   #接受消息的时间
    msg_from = itchat.search_friends(userName=msg['FromUserName'])['NickName']   #在好友列表中查询发送信息的好友昵称
    msg_time = msg['CreateTime']    #信息发送的时间
    msg_id = msg['MsgId']    #每条信息的id
    msg_content = None      #储存信息的内容
    msg_share_url = None    #储存分享的链接,比如分享的文章和音乐
    print msg['Type']
    print msg['MsgId']
    if msg['Type'] == 'Text' or msg['Type'] == 'Friends':     #如果发送的消息是文本或者好友推荐
        msg_content = msg['Text']
        print msg_content

    #如果发送的消息是附件、视屏、图片、语音
    elif msg['Type'] == "Attachment" or msg['Type'] == "Video" \
            or msg['Type'] == 'Picture' \
            or msg['Type'] == 'Recording':
        msg_content = msg['FileName']    #内容就是他们的文件名
        msg['Text'](str(msg_content))    #下载文件
        # print msg_content
    elif msg['Type'] == 'Card':    #如果消息是推荐的名片
        msg_content = msg['RecommendInfo']['NickName'] + '的名片'    #内容就是推荐人的昵称和性别
        if msg['RecommendInfo']['Sex'] == 1:
            msg_content += '性别为男'
        else:
            msg_content += '性别为女'

        print msg_content
    elif msg['Type'] == 'Map':    #如果消息为分享的位置信息
        x, y, location = re.search(
            "<location x=\"(.*?)\" y=\"(.*?)\".*label=\"(.*?)\".*", msg['OriContent']).group(1, 2, 3)
        if location is None:
            msg_content = r"纬度->" + x.__str__() + " 经度->" + y.__str__()     #内容为详细的地址
        else:
            msg_content = r"" + location
    elif msg['Type'] == 'Sharing':     #如果消息为分享的音乐或者文章,详细的内容为文章的标题或者是分享的名字
        msg_content = msg['Text']
        msg_share_url = msg['Url']       #记录分享的url
        print msg_share_url
    face_bug=msg_content

##将信息存储在字典中,每一个msg_id对应一条信息
    msg_information.update(
        {
            msg_id: {
                "msg_from": msg_from, "msg_time": msg_time, "msg_time_rec": msg_time_rec,
                "msg_type": msg["Type"],
                "msg_content": msg_content, "msg_share_url": msg_share_url
            }
        }
    )

@itchat.msg_register([TEXT, PICTURE, FRIENDS, CARD, MAP, SHARING, RECORDING, ATTACHMENT, VIDEO], isGroupChat=True)
def handle_receive_msg(msg):
    global face_bug
    msg_time_rec = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())   #接受消息的时间
    # groupid = msg['FromUserName']
    # chatroom = itchat.search_chatrooms(userName=groupid)
    msg_Actual_from = msg['ActualNickName']
    msg_from = msg_Actual_from
    msg_time = msg['CreateTime']    #信息发送的时间
    msg_id = msg['MsgId']    #每条信息的id
    msg_content = None      #储存信息的内容
    msg_share_url = None    #储存分享的链接,比如分享的文章和音乐
    print msg['Type']
    print msg['MsgId']
    if msg['Type'] == 'Text' or msg['Type'] == 'Friends':     #如果发送的消息是文本或者好友推荐
        msg_content = msg['Text']
        print msg_content

    #如果发送的消息是附件、视屏、图片、语音
    elif msg['Type'] == "Attachment" or msg['Type'] == "Video" \
            or msg['Type'] == 'Picture' \
            or msg['Type'] == 'Recording':
        msg_content = msg['FileName']    #内容就是他们的文件名
        msg['Text'](str(msg_content))    #下载文件
        # print msg_content
    elif msg['Type'] == 'Card':    #如果消息是推荐的名片
        msg_content = msg['RecommendInfo']['NickName'] + '的名片'    #内容就是推荐人的昵称和性别
        if msg['RecommendInfo']['Sex'] == 1:
            msg_content += '性别为男'
        else:
            msg_content += '性别为女'

        print msg_content
    elif msg['Type'] == 'Map':    #如果消息为分享的位置信息
        x, y, location = re.search(
            "<location x=\"(.*?)\" y=\"(.*?)\".*label=\"(.*?)\".*", msg['OriContent']).group(1, 2, 3)
        if location is None:
            msg_content = r"纬度->" + x.__str__() + " 经度->" + y.__str__()     #内容为详细的地址
        else:
            msg_content = r"" + location
    elif msg['Type'] == 'Sharing':     #如果消息为分享的音乐或者文章,详细的内容为文章的标题或者是分享的名字
        msg_content = msg['Text']
        msg_share_url = msg['Url']       #记录分享的url
        print msg_share_url
    face_bug=msg_content

##将信息存储在字典中,每一个msg_id对应一条信息
    msg_information.update(
        {
            msg_id: {
                "msg_from": msg_from, "msg_time": msg_time, "msg_time_rec": msg_time_rec,
                "msg_type": msg["Type"],
                "msg_content": msg_content, "msg_share_url": msg_share_url
            }
        }
    )
    
    
##这个是用于监听是否有消息撤回
@itchat.msg_register(NOTE, isFriendChat=True, isGroupChat=True, isMpChat=True)
def information(msg):
    #这里如果这里的msg['Content']中包含消息撤回和id,就执行下面的语句
    if '撤回了一条消息' in msg['Content']:
        old_msg_id = re.search("\<msgid\>(.*?)\<\/msgid\>", msg['Content']).group(1)   #在返回的content查找撤回的消息的id
        old_msg = msg_information.get(old_msg_id)    #得到消息
        print old_msg
        if len(old_msg_id)<11:  #如果发送的是表情包
            itchat.send_file(face_bug,toUserName='filehelper')
        else:  #发送撤回的提示给文件助手
            msg_body = "【"\
                       + old_msg.get('msg_from') + " 群消息撤回提醒】\n"\
                       + " 撤回了 " + old_msg.get("msg_type") + " 消息:" + "\n" \
                       + old_msg.get('msg_time_rec') + "\n" \
                       + r"" + old_msg.get('msg_content')
            #如果是分享的文件被撤回了,那么就将分享的url加在msg_body中发送给文件助手
            if old_msg['msg_type'] == "Sharing":
                msg_body += "\n就是这个链接➣ " + old_msg.get('msg_share_url')

            # 将撤回消息发送到文件助手
            itchat.send_msg(msg_body, toUserName='filehelper')
            # 有文件的话也要将文件发送回去
            if old_msg["msg_type"] == "Picture" \
                    or old_msg["msg_type"] == "Recording" \
                    or old_msg["msg_type"] == "Video" \
                    or old_msg["msg_type"] == "Attachment":
                file = '@fil@%s' % (old_msg['msg_content'])
                itchat.send(msg=file, toUserName='filehelper')
                os.remove(old_msg['msg_content'])
            # 删除字典旧消息
            msg_information.pop(old_msg_id)

# Main
itchat.auto_login(enableCmdQR=True, hotReload=True)
itchat.run()

4. Результаты операции

Во-первых,

Вы можете видеть два файла, которые я обвел красной рамкой, среди них itchat.pkl — временный файл для входа в систему, и скрипт в этом файле можно использовать для горячего входа, зеленый — это скрипт, а остальные — запуск с 17 - кеш сообщения о выводе, особенно картинка:

Потом,

Я запускаю его 24 часа в фоновом режиме, чтобы убедиться, что сообщения о снятии средств отслеживаются в режиме реального времени:

(myecs):/home/shanewa/wechat/withdraw:>

$ nohup python withdraw.py > /tmp/withdraw.py.record &

Наконец,

Видео-шоу, хе-хе:

(В видео я случайно нажал Избранное, увы, я нервничал, боялся быть побитым, ха-ха)

Когда я отправил тестовое сообщение, меня поймали, и мой коллега сделал скриншот, 😂😂😂

Другое интересное небольшое исследование, которое я провел:

[Облачная служба коротких сообщений Alibaba] Одно текстовое приветствие в день

【Huawei Mate8】Используйте NFC для имитации карты доступа

Спасибо!

Если у вас есть другие вопросы для связи, отправьте личное сообщение или электронное письмо (shanewa@qq.com).