python模仿网页版微信发送消息功能
作者:赵韶晖_ 发布时间:2022-01-15 00:12:54
标签:python,微信,发送消息
这个微信版网页版虽然繁琐,但是不是很难,全程不带加密的。有兴趣的可以试着玩一玩,如果有兴趣的话,可以完善一下,做一些比较有意思的东西。
开发环境:Windows10
开发语言:Python3.6
开发工具:pycharm
抓包工具:fiddler
抓的包如下:
import requests
import time
import re
from bs4 import BeautifulSoup
import json
import random
from copyheaders import headers_raw_to_dict
DEFAULT_HEADERS={
b'Host': b'wx.qq.com',
b'Connection': b'keep-alive',
b'Cache-Control': b'max-age=0',
b'User-Agent': b'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.84 Safari/537.36',
b'Upgrade-Insecure-Requests': b'1',
b'Accept': b'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
b'Accept-Language': b'zh-CN,zh;q=0.9',
}
def get_13_time():
return str(int(time.time()*1000))
class WXRobot(object):
def __init__(self):
self.s = requests.session()
self.s.verify = False
self.s.headers = DEFAULT_HEADERS
self.DeviceID='e'+str(random.random())[2:17]
def visit_index(self):
url = 'https://wx.qq.com/'
self.s.get(url)
def visit_jslogin(self):
url='https://login.wx.qq.com/jslogin?appid=wx782c26e4c19acffb&redirect_uri=https%3A%2F%2Fwx.qq.com%2Fcgi-bin%2Fmmwebwx-bin%2Fwebwxnewloginpage&fun=new&lang=zh_CN&_={}'.format(get_13_time())
r=self.s.get(url)
text=r.text
maths=re.findall(r'window.QRLogin.code = 200; window.QRLogin.uuid = "(.*?)";',text)[0]
uuid=str(maths)
self.uuid=uuid
def visit_vcode(self):
#获取验证码
url='https://login.weixin.qq.com/qrcode/{}'.format(self.uuid)
r=self.s.get(url)
with open('qrcode.jpg','wb') as f:
f.write(r.content)
f.flush()
f.close()
print('等待扫描验证码。。。')
def visit_login(self):
url='https://login.wx.qq.com/cgi-bin/mmwebwx-bin/login?loginicon=true&uuid={}&tip=0&_={}'.format(self.uuid,get_13_time())
r=self.s.get(url)
text=r.text
code=re.findall(r'''window.code=(.*?);''',text)[0]
# print('获取状态码', code)
if str(code)!='200':
# print('两秒后重新调用')
time.sleep(2)
self.visit_login()
elif str(code)=='200':
maths = re.findall(r'''redirect_uri="(.*?)"''', text)[0]
self.redirect_uri=maths
print('redirect_uri获取完成...',self.redirect_uri)
#得到一些关键字
def visit_newloginpage(self):
r=self.s.get(self.redirect_uri,allow_redirects=False)
text=r.text
bs=BeautifulSoup(text,'lxml')
self.skey = bs.find('skey').text
self.wxsid = bs.find('wxsid').text
self.wxuin = bs.find('wxuin').text
self.pass_ticket = bs.find('pass_ticket').text
self.isgrayscale = bs.find('isgrayscale').text
# print(self.skey,self.wxsid,self.wxuin,self.pass_ticket)
#得到初始化信息
def visit_webwxinit(self):
url='https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxinit?pass_ticket={}'.format(self.pass_ticket)
data={
"BaseRequest":{"Uin":self.wxuin ,"Sid":self.wxsid,"Skey":self.skey,"DeviceID":self.DeviceID}
}
r=self.s.post(url,json=data)
r.encoding='utf-8'
jsontext=r.json()
# =json.loads(text)
print('登录用户为:',jsontext["User"]["NickName"])
self.FromUserName=jsontext["User"]["UserName"]
self.group_list=jsontext['ContactList'] #
SyncKey=jsontext["SyncKey"]["List"]
ChatSet=jsontext["ChatSet"]
ChatSetlist=str(ChatSet).split(',')
self.ChatSet =[{"UserName":name ,"EncryChatRoomId":""} for name in ChatSetlist if name.startswith('@')]
def visit_notify(self):
url='https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxstatusnotify?pass_ticket={}'.format(self.pass_ticket)
data={
"BaseRequest": {"Uin": self.wxuin, "Sid": self.wxsid,
"Skey": self.skey,
"DeviceID": self.DeviceID},
"Code": 3,
"FromUserName": self.FromUserName,
"ToUserName": self.FromUserName,
"ClientMsgId": int(get_13_time())
}
r=self.s.post(url=url,json=data)
r.encoding='utf-8'
self.MsgID=r.json()['MsgID']
print(r.json()['MsgID'],'消息id')
#获取所有好友列表
def getcontact(self):
url='https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxgetcontact?pass_ticket={}&r={}&seq=0&skey=@{}'.format(self.pass_ticket,get_13_time(),self.skey)
r=self.s.get(url)
r.encoding='utf=8'
contactjson=r.json()
# print(contactjson)
self.MemberList=contactjson["MemberList"]
for name in self.MemberList:
print(name['NickName'],name['UserName'])
# 聊天列表
def batchgetcontact(self):
url='https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxbatchgetcontact?type=ex&r={}&pass_ticket={}'.format(get_13_time(),self.pass_ticket)
data={
"BaseRequest": {"Uin":self.wxuin,
"Sid": self.wxsid,
"Skey": self.skey,
"DeviceID": self.DeviceID},
"Count": len(self.ChatSet),
"List": self.ChatSet
}
r=self.s.post(url=url,json=data)
r.encoding='utf-8'
ContactList=r.json()["ContactList"]
for i in ContactList:
print('聊天窗口----',i.get('NickName'))
def get_local(self):
return str(time.time())+str(random.random())[2:9]
def send_msg(self):
ToUserName=input('你要发送给谁?')
msg = input('请输入你要发送的信息内容')
url='https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxsendmsg?pass_ticket={}'.format(self.pass_ticket)
data={
"BaseRequest": {"Uin":self.wxuin,
"Sid": self.wxsid,
"Skey": self.skey,
"DeviceID": self.DeviceID},
"Msg": {"Type": 1,
"Content": msg,
"FromUserName": self.FromUserName,
"ToUserName": ToUserName,
"LocalID": self.get_local(),
"ClientMsgId": self.get_local()
},
"Scene": 0
}
r=self.s.post(url=url,json=data)
json_data=r.json()
if 0 == json_data['BaseResponse']['Ret']:
print('消息发送成功')
else:
print('消息发送失败')
if __name__ == '__main__':
wx=WXRobot()
wx.visit_index()
wx.visit_jslogin()
wx.visit_vcode()
wx.visit_login()
wx.visit_newloginpage()
wx.visit_webwxinit()
wx.visit_notify()
wx.getcontact()
wx.batchgetcontact()
while True:
wx.send_msg()
# wx.x() #心跳包
# time.sleep(50)
来源:http://blog.csdn.net/u012593871/article/details/79219424


猜你喜欢
- MySQL Load Data 的多种用法一、LOAD 基本背景我们在数据库运维过程中难免会涉及到需要对文本数据进行处理,并导入
- 如果你从未为MySQL设置根用户密码,服务器在以根用户身份进行连接时不需要密码。但是,建议你为每个账户设置密码。如果你以前设置了根用户密码,
- 之前在网上查找了很多相关资料,有说设置icon高度来支持item的,有说要添加自己写指定高度的view来填充的,但是对于一个只有文字的Qco
- pandas模块pandas是一个强大的分析结构化数据的工具集;它的使用基础是Numpy(提供高性能的矩阵运算);用于数据挖掘和数据分析,同
- 写了一个抓taobao图片的爬虫,全是用if,for,while写的,比较简陋,入门作品。从网页http://mm.taobao.com/j
- 1、创建数组 var array = new Array(); var array = new Array(size);//指定数组的长度
- 一般说到组件,我首先想到的是弹窗,其他就大脑空白了。因为觉得这个是在项目中最常用的功能,提取出来方便复用的才是组件~然而我才发现这个想法是有
- 关于算法的学习,小编觉得编程语言中的算法大都有一些相通的地方,主要的方面一是了解这一算法能用来干什么,另一方面,学习它在这类编程语言中怎么实
- FF,不支持复制功能,要支持的话,很难的 js 复制功能 支持 for IE/FireFox/moz
- 一、动机(Motivate)在软件构建过程中,由于需求的改变,某些类层次结构中常常需要增加新的行为(方法),如果直接在基类中做这样的更改,将
- 常规方案使用FileReader以utf-8格式读取文件,根据文件内容是否包含乱码字符�,来判断文件是否为utf-8。如果存在�,即文件编码
- 题目描述给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它
- 前言后端开发中为了防止一次性加载太多数据导致内存、磁盘IO都开销过大,经常需要分页展示,这个时候就需要用到MySQL的LIMIT关键字。但你
- mysql-5.7以后压缩包安装有了不小的变化,本文针对之前安装mysql5.7.18的笔记进行了总结,分享给大家第一步:到官网下载http
- 如下所示:from bs4 import BeautifulSouppath = './web/new_index.html'
- 一.__eq__方法在我们定义一个类的时候,常常想对一个类所实例化出来的两个对象进行判断这两个对象是否是完全相同的。一般情况下,我们认为如果
- 概述已经Swoole系列的第二篇知识点了,前一篇主要的针对处理的是方案设计,这一篇主要是代码实现的内容,主要介绍高性能的原因已经实现,编程框
- python实现收支的自动计算,能够查询每笔账款的消费详情,具体内容如下1、函数需要两个文件:一个类似钱包功能,存放钱;另一个用于记录每笔花
- 如果你对长篇大论没有兴趣,也可以直接看看结果,或许你对结果感兴趣。在实际应用中经过存储、优化可以做到在超过9千万数据中的查询响应速度控制在1
- 在并发编程中,多个Goroutine访问同一块内存资源时可能会出现竞态条件,我们需要在临界区中使用适当的同步操作来以避免竞态条件。Go 语言