python qq撤回消息电脑qq怎么撤回消息

无法找到该页
无法找到该页
您正在搜索的页面可能已经删除、更名或暂时不可用。
请尝试以下操作:
确保浏览器的地址栏中显示的网站地址的拼写和格式正确无误。
如果通过单击链接而到达了该网页,请与网站管理员联系,通知他们该链接的格式不正确。
单击按钮尝试另一个链接。
HTTP 错误 404 - 文件或目录未找到。Internet 信息服务 (IIS)
技术信息(为技术支持人员提供)
转到 并搜索包括&HTTP&和&404&的标题。
打开&IIS 帮助&(可在 IIS 管理器 (inetmgr) 中访问),然后搜索标题为&网站设置&、&常规管理任务&和&关于自定义错误消息&的主题。看我如何撤回你的QQ消息(未修复)
  具体思路:
  在用PC端(windows)聊天时,
  首先你需要把QQ聊友窗口的使用多彩气泡关闭,
  然后你给对方发送一条消息,右键你的消息,
  会有一个撤回选项,先别着急点,
  等待对方发送消息过来后,
  在点击撤回,你就会发现很神器的一幕了,
  对方发送给你的消息被你撤回了哦!
  具体截图:
  PC端:
  首先关闭 使用多彩气泡:
&&&&&& 然后我们开始聊天:
  点右键,准备撤回:
&&&&& 等对方消息过来,撤回仍在:
&&&&& 点击撤回:
&&&&&& 发现对方消息被撤回了。
  ps:第一次撤回时,可能会撤回到自己(不清楚原因,如果第一次撤回自己了,第二次就可以撤回别人了)
  手机端看自己怎么被别人撤回了:
  看见自己的消息已经过去了:
  但是发现消息已经被撤回了,上方时间没变:
【声明】:黑吧安全网()登载此文出于传递更多信息之目的,并不代表本站赞同其观点和对其真实性负责,仅适于网络安全技术爱好者学习研究使用,学习中请遵循国家相关法律法规。如有问题请联系我们,联系邮箱,我们会在最短的时间内进行处理。
上一篇:【】【】下次自动登录
现在的位置:
& 综合 & 正文
利用webqq协议使用python登录qq发消息
开源的,地址在
等有时间了写一个完整的cli qq客户端。
使用方法:python login_qq.py即可
#coding=utf-8
import urllib2
import httplib2
import random
from encryption import QQmd5
import cookielib
import requests
import getpass
import time
import json
import urllib
class webqq:
def __init__(self, user, pwd):
self.cookies = cookielib.CookieJar()
self.opener = urllib2.build_opener(
urllib2.HTTPHandler(),
urllib2.HTTPSHandler(),
urllib2.HTTPCookieProcessor(self.cookies),
urllib2.install_opener(self.opener)
self.user = user
self.pwd = pwd
self.mycookie = ";"
#self.clientid = ""
#self.clientid = ""
self.clientid = str(random.randint(999999))
def getSafeCode(self):
url = 'https://ssl./check?uin=' + str(self.user) + '&appid=1003903&js_ver=10017&js_type=0&login_sig=0ihp3t5ghfoonssle-98x9hy4uaqmpvu*8*odgl5vyerelcb8fk-y3ts6c3*7e8-&u1=http%3A%2F%%2Floginproxy.html&r=0.0724'
req = urllib2.Request(url)
#self.mycookie += "confirmuin=" + self.user + ";"
#req.add_header('Cookie', self.mycookie)
= urllib2.urlopen(req)
#cs = ['%s=%s' %
(c.name, c.value) for c in self.cookies]
#self.mycookie += ";".join(cs)
verifycode = re.search(r"'(\d)','(.+)','(.+)'", req.read())
self.check = verifycode.group(1)
self.verifycode1 = verifycode.group(2)
self.verifycode2 = verifycode.group(3)
if self.check == "1":
url = 'https://ssl./getimage?&uin='+str(self.user)+'&aid=.05' + str(random.randint(10,99))
req = urllib2.Request(url)
req = urllib2.urlopen(req)
self.fi = open("./image.jgp", "wb")
c = req.read()
else :self.fi.write(c)
self.fi.close()
self.verifycode1 = raw_input("verifer:")
print self.check, self.verifycode1, self.verifycode2
def loginGet(self):
#cs = ['%s=%s' %
(c.name, c.value) for c in self.cookies]
#self.mycookie += ";" "; ".join(cs)
login_url = 'https://ssl./login?u='+self.user +'&p=' + str(QQmd5().md5_2(self.pwd, self.verifycode1, self.verifycode2)) + '&verifycode=' + self.verifycode1 + '&webqq_type=10&remember_uin=1&login2qq=1&aid==http%3A%2F%%2Floginproxy.html%3Flogin2qq%3D1%26webqq_type%3D10&h=1&ptredirect=0&ptlang=2052&from_ui=1&pttype=1&dumy=&fp=loginerroralert&action=2-14-32487&mibao_css=m_webqq&t=1&g=1&js_type=0&js_ver=10015&login_sig=0ihp3t5ghfoonssle-98x9hy4uaqmpvu*8*odgl5vyerelcb8fk-y3ts6c3*7e8-'
req = urllib2.Request(login_url)
req.add_header("Referer", "https://ui./cgi-bin/login?target=self&style=5&mibao_css=m_webqq&appid=1003903&enable_qlogin=0&no_verifyimg=1&s_url=http%3A%2F%%2Floginproxy.html&f_url=loginerroralert&strong_login=1&login_state=10&t=")
#req.add_header("Cookie", self.mycookie)
#self.opener.addheaders.append(("Cookie", self.mycookie))
req = urllib2.urlopen(req)
print req.read()
for cookie in self.cookies:
print cookie.name, ":",
cookie.value
if cookie.name == 'ptwebqq':
self.ptwebqq = cookie.value
print urllib2.urlopen('/web2/get_msg_tip?uin=&tp=1&id=0&retype=1&rc=0&lv=3&t=4').read()
#cs = ['%s=%s' %
(c.name, c.value) for c in self.cookies]
#self.mycookie += ";" "; ".join(cs)
def loginPost(self):
url = 'http://d./channel/login2'
data = 'r=%7B%22status%22%3A%22online%22%2C%22ptwebqq%22%3A%22' + self.ptwebqq + '%22%2C%22passwd_sig%22%3A%22%22%2C%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3Anull%7D&clientid='+self.clientid+'&psessionid=null'
req = urllib2.Request(url, data)
#req.add_header('Cookie', self.mycookie)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=2')
req = urllib2.urlopen(req)
self.result = json.load(req)
print self.result['result']['vfwebqq'], self.result['result']['psessionid']
def getGroupList(self):
url = 'http://s./api/get_group_name_list_mask2'
data = 'r=%7B%22vfwebqq%22%3A%22'+self.result['result']['vfwebqq'] +'%22%7D'
req = urllib2.Request(url, data)
req.add_header('Referer', 'http://s./proxy.html?v=&callback=1&id=1')
req = urllib2.urlopen(req)
self.group = json.load(req)
def getFriend(self):
url = 'http://s./api/get_user_friends2'
data = 'r=%7B%22vfwebqq%22%3A%22'+self.result['result']['vfwebqq'] +'%22%7D'
req = urllib2.Request(url, data)
req.add_header('Referer', 'http://s./proxy.html?v=&callback=1&id=1')
req = urllib2.urlopen(req)
self.friend = json.load(req)
print self.friend
def getMeg(self):
print urllib2.urlopen('/web2/get_msg_tip?uin=&tp=1&id=0&retype=1&rc=0&lv=3&t=4').read()
def poll2(self):
url = 'http://d./channel/poll2'
data ='r=%7B%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3A%22'+self.result['result']['psessionid']+'%22%2C%22key%22%3A0%2C%22ids%22%3A%5B%5D%7D&clientid='+self.clientid+'&psessionid='+self.result['result']['psessionid']
req = urllib2.Request(url, data)
#req.add_header('Cookie', self.mycookie)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=3')
result = json.load(urllib2.urlopen(req))
print result
def sendMsg(self, uin, msg):
url = 'http://d./channel/send_buddy_msg2'
data = 'r=%7B%22to%22%3A'+uin+'%2C%22face%22%3A237%2C%22content'+urllib.quote(r'":"[\"'+msg+r'\",\"\\n【提示:此用户正在使用shift webQq】\",[\"font\",{\"name\":\"宋体\",\"size\":\"10\",\"style\":[0,0,0],\"color\":\"000000\"}]]","')+'msg_id%22%3AC%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3A%22'+self.result['result']['psessionid']+'%22%7D&clientid='+self.clientid+'&psessionid='+self.result['result']['psessionid']
req = urllib2.Request(url, data)
#req.add_header('Cookie', self.mycookie)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=2')
print urllib2.urlopen(req).read()
def sendQunMsg(self, uin, msg):
url = 'http://d./channel/send_qun_msg2'
data = 'r=%7B%22group_uin%22%3A'+uin+'%2C%22face%22%3A237%2C%22content'+urllib.quote(r'":"[\"'+msg+r'\",\"\\n【提示:此用户正在使用shift webQq】\",[\"font\",{\"name\":\"宋体\",\"size\":\"10\",\"style\":[0,0,0],\"color\":\"000000\"}]]","')+'msg_id%22%3AC%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3A%22'+self.result['result']['psessionid']+'%22%7D&clientid='+self.clientid+'&psessionid='+self.result['result']['psessionid']
req = urllib2.Request(url, data)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=2')
print urllib2.urlopen(req).read()
def main():
user = raw_input('QQ:')
pwd = getpass.getpass('password: ')
qq = webqq(user, pwd)
qq.getSafeCode()
qq.loginGet()
qq.loginPost()
qq.getGroupList()
qq.getFriend()
time.sleep(0.5)
qq.poll2()
for i in range(100):
print 'to', qq.friend['result']['info'][0]['uin']
print 'to', qq.group['result']['gnamelist'][10]
#qq.sendMsg(str(qq.friend['result']['info'][0]['uin']), 'clientjsfzhiyong')
for _ in xrange(i):
ms += '。'
qq.sendQunMsg(str(qq.group['result']['gnamelist'][10]['gid']), ms)
#qq.sendMsg('', 'geisf')
if __name__ == "__main__":
&&&&推荐文章:
【上篇】【下篇】python+qq聊天机器人_壮志凌云
python+qq聊天机器人
python+qq聊天机器人&相关文章
雷锋网按:本文作者傲客,i春秋授权雷锋网独家首发。写在前面微信作为时下最in最热的移动端即时通讯App,把我们的工作和生活紧密联系到了一起。一个脑洞大开的程序猿写了用开源程序改了一个微信聊天机器人,并且在不断调试中给它赋予了n多好玩的功能譬如防撤回信息之类。然后好死不死他在号称白帽黑客欢喜地的“i春秋-信息安全魔法学院”微信群中做机器人的调试,于是分分钟被凶残的坏蛋们玩坏,这个小程序猿也被微信封号处理,结果顽强不息的程序员为了突破微信封锁又做了很多逗逼尝试……因为事情过于搞笑,雷锋网特意向i春秋学院约稿,把故事前因后果梳理出来。截图比较多,但是高潮迭起,值得看完。以下是正文:前段时间用开源程序做了一个微信聊天机器人,放到i春秋魔法学院群里做调试。然后被一群黑客玩坏了。但是整个过程还是比较好玩的,所以记录下来这个事情的来龙去脉,不过提前声明,这样做是不对的,没有考虑后果就贸然跑代码测试也是不负责任的,尤其是你不知道黑客们会用什么方法帮你测试,真的有封号的风险哦,请大家不要学我!(真要测试也要用小号测试)起源——为啥要做这个死最近因为某些原因,想给自己找点事情干填补空闲时间,前一段时间在Github上看到一个微信机器人的代码,代码链接:Urinx/WeixinBot,大致功能就是用python实现一个命令行版的微信,内置了两个聊天机器人的API可以实现自动回复,但默认不开启,于是打算试一下。程序跑起来大概就是这个样子:
微信扫码登录后:
去小黄鸡和小逗机器人API网站注册两个测试key,在代码中找到自动回复的变量设置成true就可以实现消息自动回复,改好代码运行,在群里稍加引导,就被人们玩起来了。防撤回机器人原理群里正玩着高兴,我开始看代码,消息监听部分的代码大致是这样的:
分类那么细致,还有撤回消息,我果断动起了做防撤回机器人的念头,就是在有人撤回消息的时候用这个聊天机器人把撤回的消息原封不动地发回来,这个念头出来后我就离作死越来越近了。
有了上面代码的基础,撤回机器人的实现就不是难事了。最先解决最简单的文字撤回,在第一个消息分类中加入代码逻辑,将所有文字消息的文字和发信人缓存到一个字典中,形成这样一个字典结构:
{'某S':'各位表哥,有机会一起睡觉','某客':'好啊好啊','大叔':'py交易'}
当有人撤回时,程序执行到撤回分支中,用撤回的人去找刚才字典的key,取出字典中的value发送出去,拼接成如下代码:
self.webwxsendmsg('\"'+celSrc+'\"撤回了消息,撤回的消息是:'+self.msgdic.get(celSrc),msg['FromUserName'])
其中celSrc是撤回人,比如大叔撤回了消息,那么“celSrc”就是大叔,从字典中找到key为“大叔”的对象,对应的value就是“py交易”这样再把消息发回到消息源中就实现了这样的效果:“大叔”撤回了消息,撤回的消息是:py交易。其实这种写法是有bug的,我先不说,可以在下面回复我,最好带解决方案哦。调试过程我并没有特别好的python功底(我是做.NET、前端和的,不过我胆大,啥代码都敢碰),而且手头没有python断点调试工具,只能通过print打印调试,并且犯二的用了自己的微信号调试,调试过程还算顺利,很快就满足了基本需求:
看着代码稳定运行了,我就去干别的了,就在这时候被群友玩坏了:
类似的超长消息发了十几条左右被我发现了,马上关闭了程序,但已经晚了,我被微信关了小黑屋……
我意识到我没有写字数限制,导致群里发多长的消息再撤回我都原封不动的发出来,构成炸群行为。记得我被封杀前的最后几条消息就是说我要写字数限制,然而微信并没有给我这个改正的机会。铁窗泪——微信小黑屋规则探索微信被封是啥滋味的?首先,发消息肯定没戏。
发个朋友圈通知下大家吧,门都没有。
我基本与外界隔绝了联系,放弃了任何希望,只望老实改过,好好做人,就在这时,傲客(注:i春秋魔法学院微信群群主)给我发了个红包,我发现我竟然可以正常抢红包。
红包功能不受限制的话,我是不是可以利用一下?
哈哈哈,机(dou)智(bi)的傲客,我发红包他也发红包。发现这个新大陆之后我至少可以用红包简单地跟我的微信好友沟通了,可以让常联系的人加我小号,不会以为我消失。我找到了封号后的沟通方式。感受与思考曾经在知乎上看到这样一篇文章,一个俄罗斯程序员,生活在终端里,只要任何事情花费时间超过了90秒,他一定会写一个脚本自动化实现。
比如工作日晚上九点之后这名程序员的运维服务器中还有正在运行的SSH进程,就会给妻子发一个今天加班的短信,并从文本库中随机选取一句加班理由。早上8点45分服务器中依然没有活动的SSH进程会自动向BOSS发一封“今天我身体不适的”的邮件,并随机附上一段请假理由。
还有一个老子要喝咖啡的脚本,这个脚本在执行之后,会先精确等候17秒,然后打开一个SSH进程,远程连接到公司的咖啡机,然后传送一堆代码过去,咖啡机就会煮一份中杯半咖啡因的拿铁咖啡,然后精确等待24秒后,再倒进咖啡杯里。这个脚本运行的全程,正好是这名程序员从自己的办公桌前起身,走到咖啡机前所需要花费的时间。(此项目开源在github中:hacker-scripts)
我的这次作死经历也可以探索出更多的自动化解决方案,防撤回只是微信机器人的一个有趣的玩法,自动请假完全不在话下,抛开微信,生活中那么多重复性操作也可以作为探索用代码去实现。
试想一个iOS开发狗的某一天,清晨,音箱从你最近听过的播放列表中挑选你最喜欢的歌曲叫你起床,并自动播报当天天气和空气质量,提醒你是否需要带伞带口罩,面包机早已烤好面包。出门后服务器自动向优步发出叫车请求。到公司后自动将未完成的工作发到你的邮箱,并自动从项目管理系统中收集新的bug,从AppStore中抓取低星评价并告知你。你的微信可以自动回复客服推上来的重复性问题,工作时间长了自动提醒你活动一下,女神来消息自动回复永不错过,写好的PPT、报告、流程图放到某个文件夹中自动发送邮件给相关人,晚上加班晚了自动发微信告知老婆/父母……这一切都来自你的代码,想想是不是蛮激动的?(雷锋网注:神奇的代码,跪服)尾巴高中时,晚上做完作业,窝在一间小屋子中,拿着父母换下来的单色屏旧手机,背着父母偷偷的给心动的女生发短信,或核对当天的作业,或含蓄的聊天表达心中的波澜。每条一毛钱,70字以内,安全的送达到对方的手机上,安心、踏实。如今,微信成为了我们最重要的沟通方式。我们多久没有发过短信,多久没有登过QQ?我们的手机号码都已不再重要了,有微信就够了。微信提供的服务固然便捷,我们的社交圈子大了,微信加的好友越来越多,人与人之间似乎也越来越近,我们好像可以联通整个世界。但当微信真的无法为我们服务的时候,会发现,有那么一部分人只能存在你的记忆中了……
以下内容已过滤百度推广
日&-&借助python 的 aiml 包,我们很容易实现人工智能聊天机器人。aiml 指的是 artificial intelligence markup language (人工智能标记语言),它不过是简单...&&普通
ai聊天机器人小黄鸡的工作可以被分成两个部分:训练+匹配。(其实很多ai的东西都...///wong2/xiaohuangji,他们使用pyt...&&普通
日&-&用python 来编写一个 irc 聊天机器人可算是一个有用又有趣的事,每一个学习 python 的人都不妨依照这篇教程尝试一下。链接 | 来源...&&普通
日&-&借助python 的 aiml 包,我们很容易实现人工智能聊天机器人。aiml,全名为...采用python实现简单qq单用户机器人的方法 使用python的tornado框架实现一个简单的webqq...&&普通
日&-&清雨影 ,c,vb,python,matlab,intel家的汇编 50 人赞同
你们都给洒家让开!身为给女朋友写过一个聊天机器人的机械类专业学生来说一下:开发的时候拿的是...&&普通
前一段时间在github上看到一个微信机器人的代码,代码链接:urinx/weixinbot,大致功能就是用python实现一个命令行版的微信,内置了两个聊天机器人的api可以实现自动...&&普通
日&-&python 开源软件 go开源软件 js开源软件问答
技术问答 >>
技术分享 >>
...qq聊天机器人 qqrobot 编辑/纠错 分享到:
已用 +1 收藏 +0 容联号码卫士...&&普通
日&-&python可以很方便地利用tornado框架以及aiml搭建一个聊天机器人微信公众号,本文简单...qq_: 我提个问题,如何让机器人发本地图片或者文件以及...&&普通
日&-&webqq2协议分析和qq聊天机器人简单实现 通过webqq接口,可以实现发送qq消息接收qq消息等,这样,想实现一个qq聊天机器人,就不是什么难事情了了,下面开始...&&普通利用webqq协议使用python登录qq发消息 - 推酷
利用webqq协议使用python登录qq发消息
开源的,地址在
等有时间了写一个完整的cli qq客户端。
使用方法:python login_qq.py即可
#coding=utf-8
import urllib2
import httplib2
import random
from encryption import QQmd5
import cookielib
import requests
import getpass
import time
import json
import urllib
class webqq:
def __init__(self, user, pwd):
self.cookies = cookielib.CookieJar()
self.opener = urllib2.build_opener(
urllib2.HTTPHandler(),
urllib2.HTTPSHandler(),
urllib2.HTTPCookieProcessor(self.cookies),
urllib2.install_opener(self.opener)
self.user = user
self.pwd = pwd
self.mycookie = &;&
#self.clientid = &&
#self.clientid = &&
self.clientid = str(random.randint(999999))
def getSafeCode(self):
url = 'https://ssl./check?uin=' + str(self.user) + '&appid=1003903&js_ver=10017&js_type=0&login_sig=0ihp3t5ghfoonssle-98x9hy4uaqmpvu*8*odgl5vyerelcb8fk-y3ts6c3*7e8-&u1=http%3A%2F%%2Floginproxy.html&r=0.0724'
req = urllib2.Request(url)
#self.mycookie += &confirmuin=& + self.user + &;&
#req.add_header('Cookie', self.mycookie)
= urllib2.urlopen(req)
#cs = ['%s=%s' %
(c.name, c.value) for c in self.cookies]
#self.mycookie += &;&.join(cs)
verifycode = re.search(r&'(\d)','(.+)','(.+)'&, req.read())
self.check = verifycode.group(1)
self.verifycode1 = verifycode.group(2)
self.verifycode2 = verifycode.group(3)
if self.check == &1&:
url = 'https://ssl./getimage?&uin='+str(self.user)+'&aid=.05' + str(random.randint(10,99))
req = urllib2.Request(url)
req = urllib2.urlopen(req)
self.fi = open(&./image.jgp&, &wb&)
c = req.read()
else :self.fi.write(c)
self.fi.close()
self.verifycode1 = raw_input(&verifer:&)
print self.check, self.verifycode1, self.verifycode2
def loginGet(self):
#cs = ['%s=%s' %
(c.name, c.value) for c in self.cookies]
#self.mycookie += &;& &; &.join(cs)
login_url = 'https://ssl./login?u='+self.user +'&p=' + str(QQmd5().md5_2(self.pwd, self.verifycode1, self.verifycode2)) + '&verifycode=' + self.verifycode1 + '&webqq_type=10&remember_uin=1&login2qq=1&aid==http%3A%2F%%2Floginproxy.html%3Flogin2qq%3D1%26webqq_type%3D10&h=1&ptredirect=0&ptlang=2052&from_ui=1&pttype=1&dumy=&fp=loginerroralert&action=2-14-32487&mibao_css=m_webqq&t=1&g=1&js_type=0&js_ver=10015&login_sig=0ihp3t5ghfoonssle-98x9hy4uaqmpvu*8*odgl5vyerelcb8fk-y3ts6c3*7e8-'
req = urllib2.Request(login_url)
req.add_header(&Referer&, &https://ui./cgi-bin/login?target=self&style=5&mibao_css=m_webqq&appid=1003903&enable_qlogin=0&no_verifyimg=1&s_url=http%3A%2F%%2Floginproxy.html&f_url=loginerroralert&strong_login=1&login_state=10&t=&)
#req.add_header(&Cookie&, self.mycookie)
#self.opener.addheaders.append((&Cookie&, self.mycookie))
req = urllib2.urlopen(req)
print req.read()
for cookie in self.cookies:
print cookie.name, &:&,
cookie.value
if cookie.name == 'ptwebqq':
self.ptwebqq = cookie.value
print urllib2.urlopen('/web2/get_msg_tip?uin=&tp=1&id=0&retype=1&rc=0&lv=3&t=4').read()
#cs = ['%s=%s' %
(c.name, c.value) for c in self.cookies]
#self.mycookie += &;& &; &.join(cs)
def loginPost(self):
url = 'http://d./channel/login2'
data = 'r=%7B%22status%22%3A%22online%22%2C%22ptwebqq%22%3A%22' + self.ptwebqq + '%22%2C%22passwd_sig%22%3A%22%22%2C%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3Anull%7D&clientid='+self.clientid+'&psessionid=null'
req = urllib2.Request(url, data)
#req.add_header('Cookie', self.mycookie)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=2')
req = urllib2.urlopen(req)
self.result = json.load(req)
print self.result['result']['vfwebqq'], self.result['result']['psessionid']
def getGroupList(self):
url = 'http://s./api/get_group_name_list_mask2'
data = 'r=%7B%22vfwebqq%22%3A%22'+self.result['result']['vfwebqq'] +'%22%7D'
req = urllib2.Request(url, data)
req.add_header('Referer', 'http://s./proxy.html?v=&callback=1&id=1')
req = urllib2.urlopen(req)
self.group = json.load(req)
def getFriend(self):
url = 'http://s./api/get_user_friends2'
data = 'r=%7B%22vfwebqq%22%3A%22'+self.result['result']['vfwebqq'] +'%22%7D'
req = urllib2.Request(url, data)
req.add_header('Referer', 'http://s./proxy.html?v=&callback=1&id=1')
req = urllib2.urlopen(req)
self.friend = json.load(req)
print self.friend
def getMeg(self):
print urllib2.urlopen('/web2/get_msg_tip?uin=&tp=1&id=0&retype=1&rc=0&lv=3&t=4').read()
def poll2(self):
url = 'http://d./channel/poll2'
data ='r=%7B%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3A%22'+self.result['result']['psessionid']+'%22%2C%22key%22%3A0%2C%22ids%22%3A%5B%5D%7D&clientid='+self.clientid+'&psessionid='+self.result['result']['psessionid']
req = urllib2.Request(url, data)
#req.add_header('Cookie', self.mycookie)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=3')
result = json.load(urllib2.urlopen(req))
print result
def sendMsg(self, uin, msg):
url = 'http://d./channel/send_buddy_msg2'
data = 'r=%7B%22to%22%3A'+uin+'%2C%22face%22%3A237%2C%22content'+urllib.quote(r'&:&[\&'+msg+r'\&,\&\\n【提示:此用户正在使用shift webQq】\&,[\&font\&,{\&name\&:\&宋体\&,\&size\&:\&10\&,\&style\&:[0,0,0],\&color\&:\&000000\&}]]&,&')+'msg_id%22%3AC%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3A%22'+self.result['result']['psessionid']+'%22%7D&clientid='+self.clientid+'&psessionid='+self.result['result']['psessionid']
req = urllib2.Request(url, data)
#req.add_header('Cookie', self.mycookie)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=2')
print urllib2.urlopen(req).read()
def sendQunMsg(self, uin, msg):
url = 'http://d./channel/send_qun_msg2'
data = 'r=%7B%22group_uin%22%3A'+uin+'%2C%22face%22%3A237%2C%22content'+urllib.quote(r'&:&[\&'+msg+r'\&,\&\\n【提示:此用户正在使用shift webQq】\&,[\&font\&,{\&name\&:\&宋体\&,\&size\&:\&10\&,\&style\&:[0,0,0],\&color\&:\&000000\&}]]&,&')+'msg_id%22%3AC%22clientid%22%3A%22'+self.clientid+'%22%2C%22psessionid%22%3A%22'+self.result['result']['psessionid']+'%22%7D&clientid='+self.clientid+'&psessionid='+self.result['result']['psessionid']
req = urllib2.Request(url, data)
req.add_header('Referer', 'http://d./proxy.html?v=&callback=1&id=2')
print urllib2.urlopen(req).read()
def main():
user = raw_input('QQ:')
pwd = getpass.getpass('password: ')
qq = webqq(user, pwd)
qq.getSafeCode()
qq.loginGet()
qq.loginPost()
qq.getGroupList()
qq.getFriend()
time.sleep(0.5)
qq.poll2()
for i in range(100):
print 'to', qq.friend['result']['info'][0]['uin']
print 'to', qq.group['result']['gnamelist'][10]
#qq.sendMsg(str(qq.friend['result']['info'][0]['uin']), 'clientjsfzhiyong')
for _ in xrange(i):
ms += '。'
qq.sendQunMsg(str(qq.group['result']['gnamelist'][10]['gid']), ms)
#qq.sendMsg('', 'geisf')
if __name__ == &__main__&:
已发表评论数()
请填写推刊名
描述不能大于100个字符!
权限设置: 公开
仅自己可见
正文不准确
标题不准确
排版有问题
主题不准确
没有分页内容
图片无法显示
视频无法显示
与原文不一致

我要回帖

更多关于 qq怎么看撤回的消息 的文章

 

随机推荐