|
0×00 Háttér
Milyenek ezek a piros borítékok? Testvére fia, Huer azt mondta: "A pénz szinte összehasonlítható. A testvér és lánya, Dao Yun azt mondta: "Nem olyan jó, mint a nagynénémé, a szél miatt." "Mindenki érti a hátteret, új év van, és ez az a nap, amikor piros borítékok repkednek az égen. Csak úgy történt, hogy két napja tanultam Pythont, és még izgatottabb lettem, ezért tanulmányoztam és tanulmányoztam a Weibo piros borítékok mászását, miért a Weibo piros borítékokat az Alipay piros boríték helyett, mert csak a webet értem, és ha van energiám, lehet, hogy a jövőben tanulmányozom a whack-a-mole algoritmust is. Mivel kezdő vagyok Pythonban, ez a program a harmadik program, amit a Python megtanulása után írtam, szóval kérlek, ne vizsgálj személyesen, ha van bármilyen gödör a kódban, a hangsúly az ötleten van, ha van bármilyen gödör az ötletben, kérlek, ne mutassd személyesen, látod, az IE-nek van arca ahhoz, hogy alapértelmezett böngészőként beállítsa magát, én írok egy scum cikket is elfogadható...... Én Python 2.7-et használok, és azt mondják, hogy nagy különbség van a Python 2 és a Python 3 között.
0×01 Ötletek Túl lusta voltam, hogy szavakkal írjam, ezért rajzoltam egy vázlatot, és mindenkinek értenie kellene.
Először is, a régi szabály: először vezetj be egy olyan könyvtárat, amiről nem tudod, hogy hasznos, de nélküle nem lehet megcsinálni: [mw_shl_code=java,true]import re import urllib import urllib2 import cookielib import base64 import binascii import os import json import sys import cPickle as p import rsa[/mw_shl_code] Ezután jelölj meg néhány más változót, amelyeket később használni fogsz:
[mw_shl_code=java,true]reload(sys)sys.setdefaultencoding('utf-8&') #将字符编码置为utf-8luckyList=[] #红包列表lowest=10 #能忍受红包领奖记录最低为多少[/mw_shl_code]Itt egy rsa könyvtárat használnak, amely alapértelmezés szerint nem található a Pythonban. Telepíteni kell :https://pypi.python.org/pypi/rsa/
Letöltés után futtatjuk setpy.py telepítsük a telepítést, majd elkezdhetjük a fejlesztési lépéseket.
0×02 Weibo bejelentkezés A piros borítékok megszerzését bejelentkezés után kell végrehajtani, tehát kell lennie bejelentkezési funkciónak, a bejelentkezés nem a kulcs, hanem a sütik megőrzése, itt a cookielib együttműködése szükséges. [mw_shl_code=java,true]cj = cookielib. CookieJar()opener = urllib2.build_opener(urllib2. HTTPCookieProcessor(cj))urllib2.install_opener(opener)[/mw_shl_code] Így minden hálózati művelet nyitóval, kezeli a sütik állapotát, bár nem tudok róla sokat, de fantasztikus érzés. Ezután két modult kell bezárnunk: az egyik az adatgyűjtési modul, amely egyszerűen adatgyűjtésre szolgál, a másik pedig adatok POST-ja. [mw_shl_code=java,true]def getData(url) : try: req = urllib2. Request(url) result = opener.open(req) text = result.read() text=text.decode("utf-8").encode("gbk",'ignore') return text kivéve a Exception, e: print u' request exception, url: '+url print e def postData(url,data,header) : try: data = urllib.urlencode(data) req = urllib2. Request(url,data,header) eredmény = opener.open(req) text = result.read() return text kivéve Exception, e: print u'Request exception, url: '+url[/mw_shl_code] Ezzel a két modullal GET és POST adatot, többek között azért lehet getData dekódolni és utána kódolni, mert Win7-ben mindig összezavartam a kimenetet hibakereséskor, ezért hozzáadtam némi kódolási feldolgozást, ezek nem a lényeg, az alábbi bejelentkezési függvény a Weibo bejelentkezés magja. [mw_shl_code=java,true]def login(nick, pwd): print u"----------login----------" print "----------......----------" prelogin_url= 'http://login.sina.com.cn/sso/prelogin.php?entry=weibo&callback=sinaSSOController.preloginCallBack&su=%s&rsakt=mod&checkpin=1&client=ssologin.js(v1.4.15)&_= 1400822309846' % nick preLogin = getData(prelogin_url) servertime = re.findall('"servertime":(.+?),' , preLogin)[0] pubkey = re.findall('"pubkey":"(.+?)",' , preLogin)[0] rsakv = re.findall('"rsakv":"(.+?)",' , preLogin)[0] nonce = re.findall('"nonce":"(.+?)",' , preLogin)[0] #print bytearray('xxxx','utf-8') su = base64.b64encode(urllib.quote(nick)) rsaPublickey= int(pubkey,16) key = rsa. PublicKey(rsaPublickey,65537) message = str(servertime) +'\t' + str(nonce) + '\n' + str(pwd) sp = binascii.b2a_hex(rsa.encrypt(message,key)) header = {'User-Agent' : 'Mozilla/5.0 (kompatibilis; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)'} param = { 'entry': 'weibo', 'gateway': '1', 'from': '', 'savestate': '7', 'userticket': '1', 'ssosimplelogin': '1', 'vsnf': '1', 'vsnval': '', 'su': su, 'service': 'miniblog', 'servertime': servertime, 'nonce': nonce, 'pwencode': 'rsa2', 'sp': sp, 'encoding': 'UTF-8', 'URL': 'http://weibo.com/ajaxlogin.php?framelogin=1&callback=parent.sinaSSOController.feedBackUrlCallBack', 'returntype': 'META', 'rsakv' : rsakv, } s = postData('http://login.sina.com.cn/sso/login.php?client=ssologin.js(v1.4.15)',param,header) try: urll = re.findall("locatio remove n.replace\(\'(.+?) \'\); " , s)[0] login=getData(urll) print u"--------- Bejelentkezés sikerült! ------- "print" ----------......---------- "kivéve a kivételt, e: print u" --------- bejelentkezés sikertelen! -------" nyomtatás "----------......----------" exit(0)[/mw_shl_code]A paraméterek és titkosítási algoritmusok az internetről vannak lemásolva, nem értem túl jól, valószínűleg először időbélyeget és nyilvános kulcsot kell kérni, majd RSA titkosítást, végül a feldolgozást és benyújtani a Sina bejelentkezési felületére, miután sikeresen bejelentkeztél a Sina-ból, vissza fog adni egy Weibo címet, kérned kell, hogy a bejelentkezési státusz teljesen érvényesülhessen, A sikeres bejelentkezés után a következő kérések a jelenlegi felhasználó sütit fogják hordozni.
0×03 Kijelölt piros borítékrajz Miután sikeresen bejelentkeztem a Weibóba, alig várom, hogy találjak egy piros borítékot, hogy először kipróbáljam, persze először a böngészőben. Végül találtam egy oldalt piros borítékgombal, F12 meghívta a hibakeresőt, hogy megnézze, mit kér az adatcsomag.
Láthatod, hogy a kérés címe http://huodong.weibo.com/aj_hongbao/getlucky, két fő paraméter van: az egyik ouid, vagyis a piros borítékazonosító, ami az URL-ben látható, a másik megosztás paraméter határozza meg, hogy megosztják-e a Weibóval, és van egy _t, amire nem tudom, mire való. Elméletileg tehát a piros boríték kinyerését úgy lehet teljesíteni, hogy három paramétert küldesz be erre az URL-re, de amikor ténylegesen beküldöd a paramétereket, azt fogod tapasztalni, hogy a szerver varázsütésre visszaadja neked egy ilyen stringet: [mw_shl_code=java, igaz] {"code":303403,"msg":"Sajnálom, nincs engedélyed erre az oldalra","data":[]}[/mw_shl_code] Ne ess pánikba most, sok éves webfejlesztői tapasztalatom alapján a másik fél programozójának meg kellene ítélnie a referert, nagyon egyszerű: másold le az összes korábbi kérés fejléceit. [mw_shl_code=java,true]def getLucky(id): #抽奖程序 print u"--- húzz piros borítékot onnan:"+str(id)+"---" nyomd "----------......----------" if checkValue(id)==False: #不符合条件, ez a funkció visszatér később luckyUrl="http://huodong.weibo.com/aj_hongbao/getlucky" param={ 'ouid':id, 'share':0, '_t':0 } header= { 'cache-control':'no-cache', 'content-type':'application/x-www-form-urlencoded', 'origin':'http://huodong.weibo.com', 'Pragma':'no-cache', 'referer': 'http://huodong.weibo.com/hongbao/'+str(id), 'User-Agent':'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, mint Gecko) Chrome/33.0.1750.146 BIDUBrowser/6.x Safari/537.36', 'X-Requested-With':'XMLHttpRequest' } res = postData(luckyUrl,param, fejléce)[/mw_shl_code] Ebben az esetben elméletben nincs probléma, de valójában nincs probléma. Miután a lottó akció befejeződött, meg kell ítélnünk az állapotot, és a visszaadott felbontás egy json string, ahol a kód 100000 sikeres lesz, ha 90114, akkor a mai lottó felső határa, és a többi érték is meghibásodott, szóval: [mw_shl_code=java,true]hbRes=json.loads(res)if hbRes["code"]=='901114': #今天红包已经抢完 print u"--------- elérte a felső határt---------" nyomd "----------......----------" log('szerencsés', str(id)+'---'+str(hbRes["code"])+'---'+hbRes["data"]["title"]) exit(0)elif hbRes["code"]=='100000':#成功 print u"---------Jólétet kívánok---------" print "----------......----------" log('success',str(id)+'---'+res) exit(0) if hbRes["data"] and hbRes["data"]["title"]: print hbRes["data"]["title"] print "----------......----------" log('lucky', str(id)+'---'+str(hbRes["code"])+'---'+hbRes["data"]["title"])else: print u"---------Request error---------" print "----------......----------" log('lucky', str(id)+'---'+res)[/mw_shl_code], ahol a napló is egy testreszabott funkció, amelyet naplók rögzítésére használok: [mw_shl_code=java,true]def log(type,text): fp = open(type+'.txt','a') fp.write(text) fp.write('\r\n') fp.close()[/mw_shl_code]
|