微信防撤回

  1 # -*-encoding:utf-8-*-
  2 import os
  3 import re
  4 import shutil
  5 import time
  6 import itchat
  7 from itchat.content import *
  8
  9 # 说明:可以撤回的有文本文字、语音、视频、图片、位置、名片、分享、附件
 10
 11 # {msg_id:(msg_from,msg_to,msg_time,msg_time_rec,msg_type,msg_content,msg_share_url)}
 12 msg_dict = {}
 13
 14 # 文件存储临时目录
 15 rev_tmp_dir = "D:\PycharmProjects\CRM_System\临时文件"
 16 if not os.path.exists(rev_tmp_dir): os.mkdir(rev_tmp_dir)
 17
 18 # 表情有一个问题 | 接受信息和接受note的msg_id不一致 巧合解决方案
 19 face_bug = None
 20
 21
 22 # 将接收到的消息存放在字典中,当接收到新消息时对字典中超时的消息进行清理 | 不接受不具有撤回功能的信息
 23 # [TEXT, PICTURE, MAP, CARD, SHARING, RECORDING, ATTACHMENT, VIDEO, FRIENDS, NOTE]
 24 @itchat.msg_register([TEXT, PICTURE, MAP, CARD, SHARING, RECORDING, ATTACHMENT, VIDEO])
 25 def handler_receive_msg(msg):
 26     global face_bug
 27     # 获取的是本地时间戳并格式化本地时间戳 e: 2017-04-21 21:30:08
 28     msg_time_rec = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
 29     # 消息ID
 30     msg_id = msg[‘MsgId‘]
 31     # 消息时间
 32     msg_time = msg[‘CreateTime‘]
 33     # 消息发送人昵称 | 这里也可以使用RemarkName备注 但是自己或者没有备注的人为None
 34     msg_from = (itchat.search_friends(userName=msg[‘FromUserName‘]))["NickName"]
 35     # 消息内容
 36     msg_content = None
 37     # 分享的链接
 38     msg_share_url = None
 39     if msg[‘Type‘] == ‘Text‘  40             or msg[‘Type‘] == ‘Friends‘:
 41         msg_content = msg[‘Text‘]
 42     elif msg[‘Type‘] == ‘Recording‘  43             or msg[‘Type‘] == ‘Attachment‘  44             or msg[‘Type‘] == ‘Video‘  45             or msg[‘Type‘] == ‘Picture‘:
 46         msg_content = r"" + msg[‘FileName‘]
 47         # 保存文件
 48         msg[‘Text‘](rev_tmp_dir + msg[‘FileName‘])
 49     elif msg[‘Type‘] == ‘Card‘:
 50         msg_content = msg[‘RecommendInfo‘][‘NickName‘] + r" 的名片"
 51     elif msg[‘Type‘] == ‘Map‘:
 52         x, y, location = re.search(
 53             "<location x=\"(.*?)\" y=\"(.*?)\".*label=\"(.*?)\".*", msg[‘OriContent‘]).group(1, 2, 3)
 54         if location is None:
 55             msg_content = r"纬度->" + x.__str__() + " 经度->" + y.__str__()
 56         else:
 57             msg_content = r"" + location
 58     elif msg[‘Type‘] == ‘Sharing‘:
 59         msg_content = msg[‘Text‘]
 60         msg_share_url = msg[‘Url‘]
 61     face_bug = msg_content
 62     # 更新字典
 63     msg_dict.update(
 64         {
 65             msg_id: {
 66                 "msg_from": msg_from, "msg_time": msg_time, "msg_time_rec": msg_time_rec,
 67                 "msg_type": msg["Type"],
 68                 "msg_content": msg_content, "msg_share_url": msg_share_url
 69             }
 70         }
 71     )
 72
 73 # 收到note通知类消息,判断是不是撤回并进行相应操作
 74 @itchat.msg_register([NOTE])
 75 def send_msg_helper(msg):
 76     global face_bug
 77     if re.search(r"\<\!\[CDATA\[.*撤回了一条消息\]\]\>", msg[‘Content‘]) is not None:
 78         # 获取消息的id
 79         old_msg_id = re.search("\<msgid\>(.*?)\<\/msgid\>", msg[‘Content‘]).group(1)
 80         old_msg = msg_dict.get(old_msg_id, {})
 81         if len(old_msg_id) < 11:
 82             itchat.send_file(rev_tmp_dir + face_bug, toUserName=‘filehelper‘)
 83             os.remove(rev_tmp_dir + face_bug)
 84         else:
 85             msg_body = "告诉你一个秘密~" + "\n"  86                        + old_msg.get(‘msg_from‘) + " 撤回了 " + old_msg.get("msg_type") + " 消息" + "\n"  87                        + old_msg.get(‘msg_time_rec‘) + "\n"  88                        + "撤回了什么 ?" + "\n"  89                        + r"" + old_msg.get(‘msg_content‘)
 90             # 如果是分享存在链接
 91             if old_msg[‘msg_type‘] == "Sharing": msg_body += "\n就是这个链接? " + old_msg.get(‘msg_share_url‘)
 92
 93             # 将撤回消息发送到文件助手
 94             itchat.send(msg_body, toUserName=‘filehelper‘)
 95             # 有文件的话也要将文件发送回去
 96             if old_msg["msg_type"] == "Picture"  97                     or old_msg["msg_type"] == "Recording"  98                     or old_msg["msg_type"] == "Video"  99                     or old_msg["msg_type"] == "Attachment":
100                 file = ‘@[email protected]%s‘ % (rev_tmp_dir + old_msg[‘msg_content‘])
101                 itchat.send(msg=file, toUserName=‘filehelper‘)
102                 os.remove(rev_tmp_dir + old_msg[‘msg_content‘])
103             # 删除字典旧消息
104             msg_dict.pop(old_msg_id)
105
106
107 if __name__ == ‘__main__‘:
108     itchat.auto_login(hotReload=True)
109     itchat.run()

原文地址:https://www.cnblogs.com/bingpan/p/8722138.html

时间: 2024-11-10 15:34:51

微信防撤回的相关文章

微信开发(1)---微信防撤回功能实现

手里负责的项目都是微信端开发,微信小程序,以及公众号相关,所以最近在看微信开发的书. 今天碰巧看到一篇知乎讲如何实现微信防撤回功能,所以自己去实现了下,颇为好玩. 微信防撤回功能轻松实现~ 先贴上知乎原帖: https://zhuanlan.zhihu.com/p/25689314?utm_source=zhihu&utm_medium=social 实现思路,将接收到的消息都存进一个字典(msg_dict),接收到撤回通知时,提取撤回消息的id,从字典中进行比对,然后发送.保存.那么字典能放得

用Python教你微信防撤回(文本、图片、语音、视频、名片等...)

大家在使用微信过程中,有时候消息还没看到,就被撤回了.毕竟好奇心大家都有,明知到消息被撤回了,就更想去看一下是什么内容心里想着万一是女神给我表白了呢.. 今天就用Python来做个微信防撤回的小功能.支持文本.图片.语音.视频.名片的防撤回. 思路:利用itchat库将每次接收到的消息进行缓存.监听撤回事件,当有消失被撤回时,通过msgId去缓存中取到信息再发送给文件传输助手.这样就实现了一个简单的防撤回功能. 效果图 在这里插入图片描述 将接收的消息缓存 import itchatfrom i

Exp10 Final 微信防撤回原理与实现

一.写在前面 1.为什么做免考? 相较于考试,免考更能锻炼自身创新和探索能力,更有挑战性. 2.选做微信推送防撤回原因? 微信已经成为日常沟通中必不可少的工具,如何知道别人在你没看微信的情况下偷偷说了什么就变得很重要(嘿嘿嘿) CTF我只研究过杂项.密码学和逆向,别的部分我也不擅长所以就不做了. 二.写在中间 1.什么是防撤回? 指对方发出撤回请求,系统应答后,对方微信显示成功撤回,而我方微信显示对方撤回提示但消息依然显示在界面. 2.实验环境 实验对象:wechatwin.dll (PC 2.

Python3.5+PyQt5多线程+itchat实现微信防撤回桌面版代码

weChatThread线程类 之前一直不会python多线程,写这个程序的时候,发现不用多线程会陷入无限未响应状态.于是学了半天python多线程,但是在主函数里写的时候,发现一个问题,Ui主线程和工作线程没有分离,使用itchat等库的时候会堵塞主线程,换句话说PyQt中子线程不能操作GUI界面.之前写的多线程仍然属于Ui主线程,是其子线程,所以才造成未响应. 既然知道问题了,那就查资料解决问题,后来,在几篇博客上找到了解决办法 PyQt 分离UI主线程与工作线程 python pyqt4

微信防撤回机器人

对方发送过来的消息,我们通过dict进行保存,记录消息id和对应的消息内容,当对方撤回消息的时候,我们根据检测到的消息id,找到对应的dict中的消息内容,实现撤回的消息精准复原. 撤回的消息发送到文件传输助手 1 # coding:utf-8 2 import itchat 3 from itchat.content import TEXT 4 from itchat.content import * 5 import sys 6 import time 7 import re 8 9 rel

利用Python制作微信小助手防撤回+自动回复二合一,非常强大!

导语大家新年好呀~今天在家闲来无事,想起来之前好多人吐槽那个微信防撤回的程序不能防止群消息撤回,于是优化了下,顺手把之前微信相关的一些小作品的代码整合了一下,写了个微信小助手,在这里分享给大家.开发工具Python版本:3.6.4相关模块:wxpy模块:itchat模块:argparse模块:pyecharts模块:以及一些Python自带的模块.环境搭建安装Python并添加到环境变量,pip安装需要的相关模块即可.简介微信小助手目前支持以下四项功能. 微信消息防撤回原理:就是把接收到的消息都

老司机带你攻破微信消息防撤回功能

前言: 微信聊天的时候,一疏忽竟然错过了什么,对方撤回了一条消息,一位小妹妹给你发了一张不可描述的照片,下一秒她又后悔选择了撤回.那么到哪去寻找撤回的消息呢?难道我们就不能做点什么? 就在昨天,我的一位好友壳子@ZKeeer 使用itchat库做了小脚本写了一篇文章:初学python--微信防撤回功能改进(一个用处不大的功能) - 知乎专栏,在得到壳子的授权之后,我对他的代码进行了修改,并把代码包装成了可执行的exe文件用来造福更多有需要的朋友们. 这个工具暂时我们教叫它:wMsg wMsg能实

macOS 版微信小助手,支持微信多开、防撤回、远程控制mac、自动回复等等

微信小助手 GitHub大牛提供的微信小助手是一款插件,该插件具备多开.防撤回.免手机认证登录.自动回复.远程控制自己的 macOS.群发等众多功能 GitHub网址:https://github.com/TKkk-iOSer/WeChatPlugin-MacOS 基本功能列表 消息自动回复 消息防撤回 远程控制(已支持语音) 微信多开 第二次登录免认证 聊天置底功能 微信窗口置顶 会话多选删除 自动登录开关 通知中心快捷回复 聊天窗口表情包复制 & 存储 小助手检测更新提醒 alfred 快捷

点击微信防封短链接强制使用浏览器打开页面的遮罩层最新实现方案!

相信在微信中做推广的朋友一定都遇到这种情况的.当你需要在微信中推广的时候会发现,自己的网页被微信屏蔽了,还有就是说APP的下载链接在微信中点击是无法下载的.必须要手动点击,右上角的三个点,然后选择在浏览器中打开,才可以顺利完成! 虽然说这个对于我们比较了解微信的朋友来说是很简单,很轻松的!但是使用微信的百分之九十都是小白,他们是不知道有这部操作的. 今天要加的是一个终极解决方法:强制使用浏览器打开页面的遮罩层. 再也不用管微信如何的更新,直接判断微信的UA,然后弹出一个遮罩提示用户在浏览器中打开