前言
本篇文章作为系列第六篇文章,将实现监测微信撤回的消息的功能:
系列其它文章请参考:
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()