采用python實(shí)現(xiàn)簡(jiǎn)單QQ單用戶(hù)機(jī)器人的方法
采用python實(shí)現(xiàn)簡(jiǎn)單QQ單用戶(hù)機(jī)器人的方法如下:
一、首先我們查看一下關(guān)于3GQQ的相關(guān)協(xié)議:
對(duì)此,打開(kāi)一個(gè)支持WAP的瀏覽器,可以使用Firefox的wmlbrowser插件,打開(kāi)FF后,訪(fǎng)問(wèn)地址 https://addons.mozilla.org/zh-CN/firefox/search/?q=wmlbrowser&cat=all&x=17&y=11
二、進(jìn)入3GQQ的進(jìn)行協(xié)議分析
3GQQ的地址是:http://pt.3g.qq.com/s?aid=nLogin3gqq 用安裝了wmlbrowser插件的FF打開(kāi)頁(yè)面后,啟用firebug,即可實(shí)現(xiàn)監(jiān)視提交的數(shù)據(jù)。
三、源代碼部分:
#coding:utf-8 #基于python2.6版本開(kāi)發(fā) import httplib,urllib,os,threading,re import sys reload(sys) sys.setdefaultencoding('utf8') class PYQQ: def __init__(self): self.reqIndex = 0 #HTTP請(qǐng)求 def httpRequest(self,method,url,data={}): try: _urld = httplib.urlsplit(url) conn = httplib.HTTPConnection(_urld.netloc,80,True,3) conn.connect() data = urllib.urlencode(data) if method=='get': conn.putrequest("GET", url, None) conn.putheader("Content-Length",'0') elif method=='post': conn.putrequest("POST", url) conn.putheader("Content-Length", str(len(data))) conn.putheader("Content-Type", "application/x-www-form-urlencoded") conn.putheader("Connection", "close") conn.endheaders() if len(data)>0: conn.send(data) f = conn.getresponse() self.httpBody = f.read().encode('utf8') f.close() conn.close() except: self.httpBody='' return self.httpBody #通過(guò)首尾獲取字符串的內(nèi)容 def getCon(self,start,end): findex = self.httpBody.find(start) if findex == -1 : return None tmp = self.httpBody.split(start) eindex = tmp[1].find(end) if eindex == -1: return tmp[1][0:] else: return tmp[1][0:eindex] #獲取postfield的值 def getField(self,fd): KeyStart = '') #獲取登陸驗(yàn)證碼,并保存至當(dāng)前目錄的qqcode.gif def getSafecode(self): url = self.getCon('python_實(shí)現(xiàn)簡(jiǎn)單QQ單用戶(hù)機(jī)器人 import urllib2 pager = urllib2.urlopen(url) data=pager.read() file=open(os.getcwd()+'\qqcode.gif','w+b') file.write(data) file.close() return True #登陸QQ def login(self): self.qq = raw_input('請(qǐng)輸入QQ號(hào):'.encode('gbk')) self.pwd = raw_input('請(qǐng)輸入密碼:'.encode('gbk')) s1Back = self.httpRequest('post','http://pt.3g.qq.com/handleLogin',{'r':'240971315','qq':self.qq,'pwd':self.pwd,'toQQchat':'true','q_from':'','modifySKey':0,'loginType':1}) if s1Back.find('請(qǐng)輸入驗(yàn)證碼')!=-1: self.sid = self.getField('sid') self.hexpwd = self.getField('hexpwd') self.extend = self.getField('extend') self.r_sid = self.getField('r_sid') self.rip = self.getField('rip') if self.getSafecode(): self.safeCode = raw_input('請(qǐng)輸入驗(yàn)證碼(本文件同目錄的qqcode.gif):') else: print '驗(yàn)證碼加載錯(cuò)誤' postData = {'sid':self.sid,'qq':self.qq,'hexpwd':self.hexpwd,'hexp':'true','auto':'0', 'logintitle':'手機(jī)騰訊網(wǎng)','q_from':'','modifySKey':'0','q_status':'10', 'r':'271','loginType':'1','prev_url':'10','extend':self.extend,'r_sid':self.r_sid, 'bid_code':'','bid':'-1','toQQchat':'true','rip':self.rip,'verify':self.safeCode, } s1Back = self.httpRequest('post','http://pt.3g.qq.com/handleLogin',postData) self.sid = self.getCon('sid=','&') #print self.sid print '登陸成功'.encode('gbk') self.getMsgFun() #定時(shí)獲取消息 def getMsgFun(self): self.reqIndex = self.reqIndex + 1 s2Back = self.httpRequest('get','http://q32.3g.qq.com/g/s?aid=nqqchatMain&sid='+self.sid) if s2Back.find('alt="聊天"/>(')!=-1: #有新消息,請(qǐng)求獲取消息頁(yè)面 s3back = self.httpRequest('get','http://q32.3g.qq.com/g/s?sid='+ self.sid + '&aid=nqqChat&saveURL=0&r=1310115753&g_f=1653&on=1') #消息發(fā)起者的昵稱(chēng) if s3back.find('title="臨時(shí)會(huì)話(huà)')!=-1: _fromName = '臨時(shí)對(duì)話(huà)' else: _fromName = self.getCon('title="與','聊天') #消息發(fā)起者的QQ號(hào) _fromQQ = self.getCon('num" value="','"/>') #消息內(nèi)容 _msg_tmp = self.getCon('saveURL=0">提示)',\'<input name="msg"\') crlf = '\n' if _msg_tmp.find('\r\n')!=-1: crlf = '\r\n' _msg = re.findall(r'(.+) '+ crlf +'(.+) ',_msg_tmp) for _data in _msg: self.getMsg({'qq':_fromQQ,'nick':_fromName,'time':_data[0],'msg':str(_data[1]).strip()}) if self.reqIndex>=30: #保持在線(xiàn) _url = 'http://pt5.3g.qq.com/s?aid=nLogin3gqqbysid&3gqqsid='+self.sid self.httpRequest('get',_url) self.reqIndex = 0 t = threading.Timer(2.0,self.getMsgFun) t.start() #發(fā)送消息 #qq 目標(biāo)QQ #msg 發(fā)送內(nèi)容 def sendMsgFun(self,qq,msg): msg = unicode(msg,'utf8').encode('utf8') postData = {'sid':self.sid,'on':'1','saveURL':'0','saveURL':'0','u':qq,'msg':str(msg),} s1Back = self.httpRequest('post','http://q16.3g.qq.com/g/s?sid='+ self.sid +'&aid=sendmsg&tfor=qq',postData) print '發(fā)送消息給'.encode('gbk'),qq,'成功'.encode('gbk') #收到消息的接口,重載或重寫(xiě)該方法 def getMsg(self,data): print data['time'],"收到".encode('gbk'),data['nick'].encode('gbk'),"(",data['qq'],")的新消息".encode('gbk')," : ",data['msg'].encode('gbk') self.sendMsgFun(data['qq'],data['nick']+' ,測(cè)試消息。。')#+ data['msg']) QQ = PYQQ() QQ.login()
至此,機(jī)器人功能得以實(shí)現(xiàn)!
- python基于itchat實(shí)現(xiàn)微信群消息同步機(jī)器人
- 基于Python如何使用AIML搭建聊天機(jī)器人
- 教你用Python創(chuàng)建微信聊天機(jī)器人
- 快速實(shí)現(xiàn)基于Python的微信聊天機(jī)器人示例代碼
- python使用itchat庫(kù)實(shí)現(xiàn)微信機(jī)器人(好友聊天、群聊天)
- Python實(shí)現(xiàn)聊天機(jī)器人的示例代碼
- python實(shí)現(xiàn)機(jī)器人行走效果
- 使用Python的Tornado框架實(shí)現(xiàn)一個(gè)簡(jiǎn)單的WebQQ機(jī)器人
- python實(shí)現(xiàn)機(jī)器人卡牌
相關(guān)文章
Python多進(jìn)程同步Lock、Semaphore、Event實(shí)例
這篇文章主要介紹了Python多進(jìn)程同步Lock、Semaphore、Event實(shí)例,Lock用來(lái)避免訪(fǎng)問(wèn)沖突、Semaphore用來(lái)控制對(duì)共享資源的訪(fǎng)問(wèn)數(shù)量、Event用來(lái)實(shí)現(xiàn)進(jìn)程間同步通信,需要的朋友可以參考下2014-11-11python用opencv完成圖像分割并進(jìn)行目標(biāo)物的提取
這篇文章主要介紹了python用opencv完成圖像分割并進(jìn)行目標(biāo)物的提取,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05python美多商城項(xiàng)目開(kāi)發(fā)小結(jié)
這篇文章主要介紹了python美多商城項(xiàng)目開(kāi)發(fā)小結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02Python?threading和Thread模塊及線(xiàn)程的實(shí)現(xiàn)
這篇文章主要介紹了Python?threading和Thread模塊及線(xiàn)程的實(shí)現(xiàn),Python通過(guò)兩個(gè)標(biāo)準(zhǔn)庫(kù)thread和threading提供對(duì)線(xiàn)程的支持,threading對(duì)thread進(jìn)行了封裝,具體實(shí)現(xiàn)介紹需要的朋友可以參考一下下面文章內(nèi)容2022-06-06python3中的logging記錄日志實(shí)現(xiàn)過(guò)程及封裝成類(lèi)的操作
這篇文章主要介紹了python3中的logging記錄日志實(shí)現(xiàn)過(guò)程及封裝成類(lèi)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05Python實(shí)戰(zhàn)實(shí)現(xiàn)爬取天氣數(shù)據(jù)并完成可視化分析詳解
這篇文章主要和大家分享一個(gè)用Python實(shí)現(xiàn)的小功能:獲取天氣數(shù)據(jù),進(jìn)行可視化分析,帶你直觀(guān)了解天氣情況!感興趣的小伙伴可以學(xué)習(xí)一下2022-06-06