Перед сном напишите статью об itchat.itchat — это модуль для WeChat на python.Он очень мощный и глупый в использовании.Вы гарантированно узнаете его, когда увидите.
Код в этой статье основан на Python.
Платформа для запуска кода — Alibaba Cloud ECS CentOS версии 6.5.
Вступительное отступление! ! !
Я супер шлюха, пока она в группе, в которой я состою, все монстры и монстры не хотят снимать новости! Эй Эй Эй!
1. модуль чата
Информация очень полная, поэтому больше не буду многословен, просто перейду сразу по ссылке:
Python реализует интерфейс WeChat (itchat)
Интерфейс WeChat python -- документация itchat
Проще говоря, itchat использует веб-версию WeChat, которая имитирует процесс входа на веб-страницу с помощью WeChat, поэтому то, что можно сделать в веб-версии WeChat, itchat может делать, за исключением моментов, потому что моментов еще нет. открыл веб-интерфейс.
2. Принцип просмотра сообщений о выводе средств WeChat
Кэшируйте каждое сообщение, а затем отправьте вам уже подготовленное сообщение, когда обнаружит, что сообщение было отозвано.
Несколько звонков:
- msg_register регистрирует типы сообщений, которые необходимо отслеживать, а объектами операций следующих функций являются только что зарегистрированные типы сообщений, которые могут быть текстом, изображениями, официальными сообщениями учетной записи и групповыми сообщениями. . .
- "isGroupChat=True" в регистрации указывает на то, что групповое сообщение зарегистрировано, то есть отзыв группового сообщения некуда спрятать. Конечно, следующая функция предназначена для групповых сообщений.
- После обнаружения отзыва сообщения, вот, itchat.send_msg(msg_body, toUserName='filehelper'), скрипт отправляет сообщение файловому хелперу, конечно, можно и самому себе отправить (имя пользователя это поле не нужно ), но я в основном различаю сообщения опровержения.
- enableCmdQR=True в itchat.auto_login(enableCmdQR=True, hotReload=True) при входе означает генерировать QR-код в символьном формате, если этот параметр не добавить, будет генерироваться QR-код в формате изображения, который нельзя открыть в CentOS.Поэтому этот домен обязательно должен быть, второй hotReload, как следует из названия, заключается в том, что после того, как вы один раз войдете в систему, просканировав код мобильным телефоном, при следующем запуске скрипта вам не нужно сканировать код и войдите в систему напрямую. Конечно, предполагается, что вы не вошли в систему на других платформах.
3. Исходный код
# 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
}
}
)
@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_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
}
}
)
##这个是用于监听是否有消息撤回
@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)
# Main
itchat.auto_login(enableCmdQR=True, hotReload=True)
itchat.run()
4. Результаты операции
Во-первых,
Вы можете видеть два файла, которые я обвел красной рамкой, среди них itchat.pkl — временный файл для входа в систему, и скрипт в этом файле можно использовать для горячего входа, зеленый — это скрипт, а остальные — запуск с 17 - кеш сообщения о выводе, особенно картинка:
Потом,
Я запускаю его 24 часа в фоновом режиме, чтобы убедиться, что сообщения о снятии средств отслеживаются в режиме реального времени:
(myecs):/home/shanewa/wechat/withdraw:>
$ nohup python withdraw.py > /tmp/withdraw.py.record &
Наконец,
Видео-шоу, хе-хе:
(В видео я случайно нажал Избранное, увы, я нервничал, боялся быть побитым, ха-ха)
Когда я отправил тестовое сообщение, меня поймали, и мой коллега сделал скриншот, 😂😂😂
Другое интересное небольшое исследование, которое я провел:
[Облачная служба коротких сообщений Alibaba] Одно текстовое приветствие в день
【Huawei Mate8】Используйте NFC для имитации карты доступа
Спасибо!
Если у вас есть другие вопросы для связи, отправьте личное сообщение или электронное письмо (shanewa@qq.com).