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 字符串中的字符倒转
Sep 06 Python
python mysqldb连接数据库
Mar 16 Python
Python实现partial改变方法默认参数
Aug 18 Python
Python正则表达式知识汇总
Sep 22 Python
Python3利用SMTP协议发送E-mail电子邮件的方法
Sep 30 Python
python实现百度语音识别api
Apr 10 Python
python遍历一个目录,输出所有的文件名的实例
Apr 23 Python
Python Django Vue 项目创建过程详解
Jul 29 Python
Python基于pandas绘制散点图矩阵代码实例
Jun 04 Python
Python通过类的组合模拟街道红绿灯
Sep 16 Python
基于Python爬取素材网站音频文件
Oct 21 Python
Python Socket多线程并发原理及实现
Dec 11 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
PHP 最大运行时间 max_execution_time修改方法
2010/03/08 PHP
如何利用PHP执行.SQL文件
2013/07/05 PHP
纯PHP生成的一个树叶图片画图例子
2014/04/16 PHP
jquery 图片轮换效果
2010/07/29 Javascript
js 中{},[]中括号,大括号使用详解
2011/05/12 Javascript
如何设置iframe高度自适应在跨域情况下的可用方法
2013/09/06 Javascript
JavaScript将Web页面内容导出到Word及Excel的方法
2015/02/13 Javascript
Knockout自定义绑定创建方法
2015/12/26 Javascript
javascript自定义滚动条实现代码
2020/04/20 Javascript
详解JavaScript for循环中发送AJAX请求问题
2020/06/23 Javascript
jquery计算出left和top,让一个div水平垂直居中的简单实例
2016/07/13 Javascript
Js 获取、判断浏览器版本信息的简单方法
2016/08/08 Javascript
JQuery中Ajax的操作完整例子
2017/03/07 Javascript
详解Vue.js中引入图片路径的几种方式
2019/06/17 Javascript
基于JavaScript 实现拖放功能
2019/09/12 Javascript
图解NodeJS实现登录注册功能
2019/09/16 NodeJs
微信小程序利用云函数获取手机号码
2019/12/17 Javascript
浅析Vue 中的 render 函数
2020/02/28 Javascript
[07:08]2014DOTA2西雅图国际邀请赛 小组赛7月11日TOPPLAY
2014/07/11 DOTA
[01:03:33]Alliance vs TNC 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/18 DOTA
采用Psyco实现python执行速度提高到与编译语言一样的水平
2014/10/11 Python
使用Python的urllib和urllib2模块制作爬虫的实例教程
2016/01/20 Python
Python实现的归并排序算法示例
2017/11/21 Python
django框架使用orm实现批量更新数据的方法
2019/06/21 Python
使用Python自动生成HTML的方法示例
2019/08/06 Python
Pycharm中出现ImportError:DLL load failed:找不到指定模块的解决方法
2019/09/17 Python
解决torch.autograd.backward中的参数问题
2020/01/07 Python
python制作一个简单的gui 数据库查询界面
2020/11/19 Python
英国外籍人士的在线超市:British Corner Shop
2019/06/03 全球购物
联想智利官方网站:Lenovo Chile
2020/06/03 全球购物
怎样声明子类
2013/07/02 面试题
小学运动会入场词
2015/07/18 职场文书
2015年除四害工作总结
2015/07/23 职场文书
pytorch--之halfTensor的使用详解
2021/05/24 Python
使用goaccess分析nginx日志的详细方法
2021/07/09 Servers
nginx之内存池的实现
2022/06/28 Servers