Python 实现微信防撤回功能


Posted in Python onApril 29, 2019

在微信上突然看到“XXX撤回一条消息”的时候,心里痒不痒?现在就教你如何实现消息防撤回的功能。不限手机型号、手机无需root,只要微信号可以登上网页版就可以了(部分不常用和新申请的账号会登不上网页版)。

环境

Centos7 
python2.7
itchat

代码

# 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
  }
 }
 )
##这个是用于监听是否有friend消息撤回
@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)
@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_Actual_from = msg['User']
 # msg_from = msg_Actual_from['Self']['NickName']
 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
  }
 }
 )
##这个是用于监听是否有Group消息撤回
@itchat.msg_register(NOTE, 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 (enableCmdQr = True 时,将会生成二维码图片,如 =2 时二维码乱码的话 改为1 即可
itchat.auto_login(enableCmdQR=2, hotReload=True) 
itchat.run()

如果想看懂代码的话,在有python一点基础的前提下搞懂 Python 中的 装饰器  概念。下面是用到itchat中主要的一段代码

def msg_register(self, msgType, isFriendChat=False, isGroupChat=False, isMpChat=False):
 ''' a decorator constructor
 return a specific decorator based on information given '''
 if not (isinstance(msgType, list) or isinstance(msgType, tuple)):
 msgType = [msgType]
 def _msg_register(fn):
 for _msgType in msgType:
  if isFriendChat:
  self.functionDict['FriendChat'][_msgType] = fn
  if isGroupChat:
  self.functionDict['GroupChat'][_msgType] = fn
  if isMpChat:
  self.functionDict['MpChat'][_msgType] = fn
  if not any((isFriendChat, isGroupChat, isMpChat)):
  self.functionDict['FriendChat'][_msgType] = fn
 return fn
 return _msg_register

运行

1.连接云服务器,安装pip 

Python 实现微信防撤回功能

2.使用pip 安装 itchat库 (一个利用微信网页版api接口写的,有兴趣的话可以鼓捣鼓捣)

Python 实现微信防撤回功能

3.将脚本文件上传到云服务器

Python 实现微信防撤回功能

4.运行代码

1)扫码登录

Python 实现微信防撤回功能

2)登录成功

Python 实现微信防撤回功能

效果

发送消息 

Python 实现微信防撤回功能 

收到消息 

Python 实现微信防撤回功能 

开始撤回 

 Python 实现微信防撤回功能 

撤回通知

Python 实现微信防撤回功能

总结

以上所述是小编给大家介绍的Python 实现微信防撤回功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
Python字符串的encode与decode研究心得乱码问题解决方法
Mar 23 Python
Python 获取当前所在目录的方法详解
Aug 02 Python
python 实现判断ip连通性的方法总结
Apr 22 Python
python实现点对点聊天程序
Jul 28 Python
python使用多进程的实例详解
Sep 19 Python
Python基础教程之异常详解
Jan 10 Python
实例详解Matlab 与 Python 的区别
Apr 26 Python
jupyter notebook 中输出pyecharts图实例
Apr 23 Python
tensorflow ckpt模型和pb模型获取节点名称,及ckpt转pb模型实例
Jan 21 Python
基于python调用jenkins-cli实现快速发布
Aug 14 Python
PyQt5结合matplotlib绘图的实现示例
Sep 15 Python
python爬取”顶点小说网“《纯阳剑尊》的示例代码
Oct 16 Python
python程序控制NAO机器人行走
Apr 29 #Python
Django web框架使用url path name详解
Apr 29 #Python
Python对HTML转义字符进行反转义的实现方法
Apr 28 #Python
Django使用redis缓存服务器的实现代码示例
Apr 28 #Python
django的settings中设置中文支持的实现
Apr 28 #Python
Django数据库类库MySQLdb使用详解
Apr 28 #Python
Django中如何防范CSRF跨站点请求伪造攻击的实现
Apr 28 #Python
You might like
批量获取memcache值并按key的顺序返回的实现代码
2011/06/14 PHP
PHP registerXPathNamespace()函数讲解
2019/02/03 PHP
PHP FileSystem 文件系统常用api整理总结
2019/07/12 PHP
在chrome中window.onload事件的一些问题
2010/03/01 Javascript
javascript常用的正则表达式实例
2014/05/15 Javascript
javascript实现的元素拖动函数宿主为浏览器
2014/07/21 Javascript
node.js中的http.request方法使用说明
2014/12/14 Javascript
AngularJS实现一次监听多个值发生的变化
2016/08/31 Javascript
使用bootstrap实现多窗口和拖动效果
2016/09/22 Javascript
微信小程序 MINA文件结构
2016/10/17 Javascript
给easyui的datebox控件添加清空按钮的实现方法
2016/11/09 Javascript
收藏AngularJS中最重要的核心功能
2017/07/09 Javascript
nodejs的路径问题的解决
2018/06/30 NodeJs
微信小程序webSocket的使用方法
2020/02/20 Javascript
Python使用asyncio包处理并发详解
2017/09/09 Python
Python实现读取及写入csv文件的方法示例
2018/01/12 Python
使用pytorch进行图像的顺序读取方法
2018/07/27 Python
Python通过for循环理解迭代器和生成器实例详解
2019/02/16 Python
python列表推导式入门学习解析
2019/12/02 Python
python实现mask矩阵示例(根据列表所给元素)
2020/07/30 Python
解决python3输入的坑——input()
2020/12/05 Python
基于css3实现漂亮便签样式
2013/03/18 HTML / CSS
HTML5标签与HTML4标签的区别示例介绍
2013/07/18 HTML / CSS
德国消费电子产品购物网站:Guter Kauf
2020/09/15 全球购物
在对linux系统分区进行格式化时需要对磁盘簇(或i节点密度)的大小进行选择,请说明选择的原则
2012/01/13 面试题
印刷工程专业应届生求职信
2013/09/29 职场文书
门卫岗位职责
2013/11/15 职场文书
浪费资源的建议书
2014/03/12 职场文书
学习十八大的心得体会
2014/09/12 职场文书
实习指导教师评语
2014/12/30 职场文书
2015年学生会主席工作总结
2015/04/21 职场文书
2016廉政教育学习心得体会
2016/01/25 职场文书
工作转正自我鉴定范文
2019/06/21 职场文书
JPA如何使用entityManager执行SQL并指定返回类型
2021/06/15 Java/Android
Java SSM配置文件案例详解
2021/08/30 Java/Android
JVM的类加载器和双亲委派模式你了解吗
2022/03/13 Java/Android