python模仿網(wǎng)頁(yè)版微信發(fā)送消息功能
這個(gè)微信版網(wǎng)頁(yè)版雖然繁瑣,但是不是很難,全程不帶加密的。有興趣的可以試著玩一玩,如果有興趣的話,可以完善一下,做一些比較有意思的東西。
開發(fā)環(huán)境:Windows10
開發(fā)語(yǔ)言:Python3.6
開發(fā)工具: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): #獲取驗(yàn)證碼 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('等待掃描驗(yàn)證碼。。。') 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('獲取狀態(tài)碼', code) if str(code)!='200': # print('兩秒后重新調(diào)用') 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) #得到一些關(guān)鍵字 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('你要發(fā)送給誰(shuí)?') msg = input('請(qǐng)輸入你要發(fā)送的信息內(nèi)容') 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('消息發(fā)送成功') else: print('消息發(fā)送失敗') 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)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python制作定時(shí)發(fā)送信息腳本的實(shí)現(xiàn)思路
- python實(shí)現(xiàn)企業(yè)微信定時(shí)發(fā)送文本消息的示例代碼
- python向企業(yè)微信發(fā)送文字和圖片消息的示例
- python3.8 微信發(fā)送服務(wù)器監(jiān)控報(bào)警消息代碼實(shí)現(xiàn)
- Python 通過微信控制實(shí)現(xiàn)app定位發(fā)送到個(gè)人服務(wù)器再轉(zhuǎn)發(fā)微信服務(wù)器接收位置信息
- Python3 itchat實(shí)現(xiàn)微信定時(shí)發(fā)送群消息的實(shí)例代碼
- python實(shí)現(xiàn)給微信指定好友定時(shí)發(fā)送消息
- python實(shí)現(xiàn)微信定時(shí)每天和女友發(fā)送消息
- 詳解用python自制微信機(jī)器人,定時(shí)發(fā)送天氣預(yù)報(bào)
- python3操作微信itchat實(shí)現(xiàn)發(fā)送圖片
- 用python發(fā)送微信消息
相關(guān)文章
python numpy生成等差數(shù)列、等比數(shù)列的實(shí)例
今天小編就為大家分享一篇python numpy生成等差數(shù)列、等比數(shù)列的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2020-02-02如何使用Selenium實(shí)現(xiàn)簡(jiǎn)單的網(wǎng)絡(luò)自動(dòng)化操作指南
Selenium是一個(gè)用于Web應(yīng)用測(cè)試的工具,Selenium測(cè)試直接運(yùn)行在瀏覽器中,就像真正的用戶在操作一樣,這篇文章主要給大家介紹了關(guān)于如何使用Selenium實(shí)現(xiàn)簡(jiǎn)單的網(wǎng)絡(luò)自動(dòng)化操作的相關(guān)資料,需要的朋友可以參考下2024-03-03解決Tensorflow2.0 tf.keras.Model.load_weights() 報(bào)錯(cuò)處理問題
這篇文章主要介紹了解決Tensorflow2.0 tf.keras.Model.load_weights() 報(bào)錯(cuò)處理問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨想過來(lái)看看吧2020-06-06教你用Python實(shí)現(xiàn)Excel表格處理
今天教各位小伙伴怎么用Python處理excel,文中有非常詳細(xì)的代碼示例及相關(guān)知識(shí)總結(jié),對(duì)正在學(xué)習(xí)python的小伙伴們很有幫助,需要的朋友可以參考下2021-05-05詳解用Pytest+Allure生成漂亮的HTML圖形化測(cè)試報(bào)告
這篇文章主要介紹了詳解用Pytest+Allure生成漂亮的HTML圖形化測(cè)試報(bào)告,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03Python自定義函數(shù)計(jì)算給定日期是該年第幾天的方法示例
這篇文章主要介紹了Python自定義函數(shù)計(jì)算給定日期是該年第幾天的方法,結(jié)合具體實(shí)例形式分析了Python日期時(shí)間計(jì)算相關(guān)操作技巧,需要的朋友可以參考下2019-05-05