采用python實現簡單QQ單用戶機器人的方法
采用python實現簡單QQ單用戶機器人的方法如下:
一、首先我們查看一下關于3GQQ的相關協議:
對此,打開一個支持WAP的瀏覽器,可以使用Firefox的wmlbrowser插件,打開FF后,訪問地址 https://addons.mozilla.org/zh-CN/firefox/search/?q=wmlbrowser&cat=all&x=17&y=11
二、進入3GQQ的進行協議分析
3GQQ的地址是:http://pt.3g.qq.com/s?aid=nLogin3gqq 用安裝了wmlbrowser插件的FF打開頁面后,啟用firebug,即可實現監(jiān)視提交的數據。
三、源代碼部分:
#coding:utf-8 #基于python2.6版本開發(fā) import httplib,urllib,os,threading,re import sys reload(sys) sys.setdefaultencoding('utf8') class PYQQ: def __init__(self): self.reqIndex = 0 #HTTP請求 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 #通過首尾獲取字符串的內容 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 = '') #獲取登陸驗證碼,并保存至當前目錄的qqcode.gif def getSafecode(self): url = self.getCon('python_實現簡單QQ單用戶機器人 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('請輸入QQ號:'.encode('gbk')) self.pwd = raw_input('請輸入密碼:'.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('請輸入驗證碼')!=-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('請輸入驗證碼(本文件同目錄的qqcode.gif):') else: print '驗證碼加載錯誤' postData = {'sid':self.sid,'qq':self.qq,'hexpwd':self.hexpwd,'hexp':'true','auto':'0', 'logintitle':'手機騰訊網','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() #定時獲取消息 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: #有新消息,請求獲取消息頁面 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ā)起者的昵稱 if s3back.find('title="臨時會話')!=-1: _fromName = '臨時對話' else: _fromName = self.getCon('title="與','聊天') #消息發(fā)起者的QQ號 _fromQQ = self.getCon('num" value="','"/>') #消息內容 _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: #保持在線 _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 目標QQ #msg 發(fā)送內容 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') #收到消息的接口,重載或重寫該方法 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']+' ,測試消息。。')#+ data['msg']) QQ = PYQQ() QQ.login()
至此,機器人功能得以實現!
相關文章
Python多進程同步Lock、Semaphore、Event實例
這篇文章主要介紹了Python多進程同步Lock、Semaphore、Event實例,Lock用來避免訪問沖突、Semaphore用來控制對共享資源的訪問數量、Event用來實現進程間同步通信,需要的朋友可以參考下2014-11-11Python?threading和Thread模塊及線程的實現
這篇文章主要介紹了Python?threading和Thread模塊及線程的實現,Python通過兩個標準庫thread和threading提供對線程的支持,threading對thread進行了封裝,具體實現介紹需要的朋友可以參考一下下面文章內容2022-06-06python3中的logging記錄日志實現過程及封裝成類的操作
這篇文章主要介紹了python3中的logging記錄日志實現過程及封裝成類的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05Python實戰(zhàn)實現爬取天氣數據并完成可視化分析詳解
這篇文章主要和大家分享一個用Python實現的小功能:獲取天氣數據,進行可視化分析,帶你直觀了解天氣情況!感興趣的小伙伴可以學習一下2022-06-06