python web微信应用(六) 监测微信撤回的消息

文章目录

  • 前言
  • 一、webwx 模块介绍
  • 二、监测微信撤回的消息


前言

本篇文章作为系列第六篇文章,将实现监测微信撤回的消息的功能:

系列其它文章请参考:
python web微信应用(一) 微信协议分析

python web微信应用(二) webwx 模块源码

python web微信应用(三) 微信智能聊天机器人

python web微信应用(四) 监测自己被群组消息 @

python web微信应用(五) 自动下载接收的图片/语音/视频

一、webwx 模块介绍

当前支持消息来源: 群组、公众号、联系人、自己
当前支持消息类型: 文本,位置,链接,图片,语音,视频,名片,表情,文件,撤回
不同消息类型所携带的字段也不同,具体如下:

类型 字段
必有字段 'senderType': 字符串类型,取值 “GROUP/SUBSCRIPTION/CONTACT/MYSELF/UNSUPPORTED”, 表示消息来源于群组/公众号/联系人/自己/不支持
'senderName': 字符串类型,表示发送者的身份,由系统分配,@@开头表示群组,@开头表示联系人或者公众号
'msgType': 字符串类型,取值 “TEXT/POSITION/IMAGE/VOICE/VIDEO/CARD/ANIMATION/FILE/REVOKE/UNSUPPORTED”, 表示消息类型是文本/位置/图片/语音/视频/名片/表情/文件/撤回/不支持
'msgId': 字符串类型,表示消息的唯一 id,由系统分配
senderType:
GROUP 'groupNickName': 字符串类型,表示发送者所在的群组昵称
'userNickName': 字符串类型,表示发送者的昵称
'userDisplayName': 字符串类型,表示发送者设置的自己在该群的显示名称,没有则为 ‘’
'meIsAt': 布尔类型,表示自己是否被 @
SUBSCRIPTION 'subscriptionNickName': 字符串类型,表示发送者公众号昵称
CONTACT 'contactNickName': 字符串类型,表示发送者昵称
'contactRemarkName': 字符串类型,表示发送者备注名
MYSELF 'myNickName': 字符串类型,表示自己的昵称
msgType:
TEXT 'content': 字符串类型,表示接收到的消息内容
POSITION 'x': 字符串类型,浮点数,表示纬度
'y': 字符串类型,浮点数,表示经度
'scale': 字符串类型,整数,表示缩放比例
'label': 字符串类型,表示位置的标签名称
'poiname': 字符串类型,表示位置的具体名称
IMAGE 'imgHeight': 整数类型,表示图片高度
'imgWidth': 整数类型,表示图片宽度
'mediaId': 字符串类型,表示图片在服务器的资源 id,由系统分配,用于下载使用
'downloadFunc': 函数类型,表示下载图片的函数
调用 msg['downloadFunc'](msg),将下载图片到当前目录,保存文件名为 img_mediaId.jpg
VOICE 'voiceLength': 整数类型,表示语音时长,单位毫秒
'mediaId': 字符串类型,表示图片在服务器的资源 id,由系统分配,用于下载使用
'downloadFunc': 函数类型,表示下载语音的函数
调用 msg['downloadFunc'](msg),将下载语音到当前目录,保存文件名为 voice_mediaId.mp3
VIDEO 'imgHeight': 整数类型,表示视频高度
'imgWidth': 整数类型,表示视频宽度
'playLength': 整数类型,表示视频时长,单位秒
'mediaId': 字符串类型,表示视频在服务器的资源 id,由系统分配,用于下载使用
'downloadFunc': 函数类型,表示下载视频的函数
调用 msg['downloadFunc'](msg),将下载视频到当前目录,保存文件名为 video_mediaId.mp4
CARD 'username': 字符串类型,表示微信号
'nickname': 字符串类型,表示昵称
'alias': 字符串类型,表示别名
'province': 字符串类型,表示省
'city': 字符串类型,表示城市
'sex': 字符串类型,表示性别,0-未知 1-男 2-女
'regionCode': 字符串类型,表示注册地
ANIMATION 'imgHeight': 整数类型,表示表情高度
'imgWidth': 整数类型,表示表情宽度
FILE 'fileName': 字符串类型,表示文件名
'encryFileName': 字符串类型,表示 encry 文件名
'fileSize': 字符串类型,表示文件大小,单位字节
'mediaId': 字符串类型,表示视频多媒体 id,由系统分配,用于下载使用
'downloadFunc': 函数类型,表示下载文件的函数
调用 msg['downloadFunc'](msg),将下载文件到当前目录,保存文件名为 ‘fileName’ 字段值
REVOKE 'revokedMsgId': 字符串类型,表示被撤回的那条消息的 id
UNSUPPORTED 没有可选字段

二、监测微信撤回的消息

微信支持 120 秒内的消息撤回,当接收到普通文本消息时,将消息缓存起来,并设置消息的生存周期为 120 秒,然后启动一个线程,每隔 1 秒钟将缓存消息的生命周期 -1,如果减到 0,则将这条消息从缓存中删除

当接收到撤销消息时,消息中可以解析出被撤回的那条消息的 id,然后通过 id 值可以在缓存中查找被撤回的消息具体内容,最后将被撤回的消息内容发送到 filehelper 或者发回给发送方

import time
import threading
import webwx

queue_msgs = {} # 缓存 120 秒以内的消息

def msg_handle(self, msg):
    if msg['msgType'] == 'TEXT':
        msg['life'] = 120
        queue_msgs[msg['msgId']] = msg

    if msg['msgType'] == 'REVOKE':
        revoked_msg = queue_msgs[msg['revokedMsgId']]
        # self.send_text(revoked_msg['content'], revoked_msg['senderName']) # 撤回的内容发回给发送方
        self.send_text(revoked_msg['content'], 'filehelper') # 撤回的内容发送到 filehelper

def clean_msgs():
    while True:
        keys = list(queue_msgs.keys())
        for key in keys:
            queue_msgs[key]['life'] -= 1
            if queue_msgs[key]['life'] == 0:
                del queue_msgs[key]
        time.sleep(1)

if __name__ == '__main__':
    threading.Thread(target=clean_msgs).start()

    weChat = webwx.webwx()
    weChat.register_msg_handle(msg_handle)
    weChat.login()
    weChat.run()

你可能感兴趣的:(python,python,微信,撤回消息,监测,撤销)