|
0×00 Предыстория
Какие красные конверты? Сын его брата, Хуэр, сказал: «Деньги почти сопоставимы. Брат и дочь Дао Юнь сказали: «Это не так хорошо, как у моей тёти из-за ветра.» «Все понимают предысторию, это Новый год, и это день, когда красные конверты разлетаются по всему небу. Так получилось, что два дня назад я выучил Python, и был более взволнован, поэтому изучал и изучал ползание красных конвертов Weibo, почему Weibo красные конверты, а не Alipay, потому что я понимаю только Интернет, и если у меня хватит сил, возможно, в будущем я также изучу алгоритм whack-a-mole. Поскольку я новичок в Python, эта программа — третья программа, которую я написал после изучения Python, так что, пожалуйста, не спрашивайте лично, если в коде есть какие-то пробелы, главное — на самой идее, если есть яма в идее, пожалуйста, не трогайте её лично, видите ли, у IE есть лицо, чтобы сделать браузер браузером по умолчанию, я тоже пишу статью для отбросов...... Я использую Python 2.7, и говорят, что между Python 2 и Python 3 есть большая разница.
0×01 Идеи Мне было лень описать это словами, поэтому я нарисовал набросок, и все должны были его понять.
Прежде всего, старое правило: сначала введите библиотеку, для которой вы не знаете, что она полезна, но без которой нельзя: [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] Затем объявите другие переменные, которые понадобятся позже:
[mw_shl_code=java,true]reload(sys)sys.setdefaultencoding('utf-8&') #将字符编码置为utf-8luckyList=[] #红包列表lowest=10 #能忍受红包领奖记录最低为多少[/mw_shl_code]Здесь используется библиотека rsa, которая по умолчанию не включена в Python. Нужно установить :https://pypi.python.org/pypi/rsa/
После скачивания запустите setpy.py установку, и тогда мы сможем начать разработку.
0×02 Вход в Weibo Действие захвата красных конвертов должно выполняться после входа, поэтому должна быть функция входа, ключ — не вход, ключ — сохранение куки, здесь требуется сотрудничество cookielib. [mw_shl_code=java,true]cj = cookielib. CookieJar()opener = urllib2.build_opener(urllib2. HTTPCookieProcessor(cj))urllib2.install_opener(opener)[/mw_shl_code] Таким образом, все сетевые операции, использующие opener, будут обрабатывать состояние cookie, хотя я мало что об этом знаю, но ощущения потрясающие. Далее нужно инкапсулировать два модуля: один — модуль сбора данных, который используется просто для получения данных, другой — для POST данных. [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') возвращает текст, кроме исключения, 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) result = opener.open(req) text = result.read() return text, кроме исключения, e: print u'Request exception, url: '+url[/mw_shl_code] С помощью этих двух модулей мы можем GET и POST данные, среди которых причина декодирования и кодирования getData в том, что в Win7 я всегда искажал вывод при отладке, поэтому добавил обработку кодирования, но это не главное, функция входа ниже — ядро входа в Weibo. [mw_shl_code=java,true]def login(nick, pwd): вывести u"----------login----------" вывести "----------......----------" 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 (совместим; 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"--------- Вход успешен! ------- «печатать» ----------......---------- «кроме исключения, например: print u» --------- неудачный вход! -------" печатать "----------......----------" exit(0)[/mw_shl_code]Параметры и алгоритмы шифрования скопированы из Интернета, я плохо понимаю, вероятно, сначала нужно запросить временную метку и публичный ключ, затем RSA-шифрование, а затем обработку и отправку в интерфейс входа Sina, после успешного входа из Sina он вернёт адрес Weibo, нужно его запросить, чтобы статус входа полностью вступил в силу, После успешного входа последующие запросы будут содержать текущий файл cookie пользователя.
0×03 Чертеж с выделенным красным конвертом После успешного входа в Weibo я с нетерпением жду, когда сначала найду красный конверт, чтобы попробовать его, конечно же, сначала в браузере. Наконец, я нашёл страницу с красной кнопкой конверта, F12 вызвал отладчик, чтобы узнать, что запрашивает пакет данных.
Вы видите, что адрес запроса — http://huodong.weibo.com/aj_hongbao/getlucky, есть два основных параметра: один — ouid, то есть красный идентификатор конверта, который отображается в URL, другой параметр share, определяет, стоит ли делиться им в Weibo, и есть _t для чего он нужен. Теоретически вы можете завершить извлечение красных конвертов, отправив три параметра на этот URL, но когда вы действительно отправите параметры, сервер волшебным образом вернёт такую строку: [mw_shl_code=java, true] {"code":303403,"msg":"Извините, у вас нет разрешения на доступ к этой странице","data":[]}[/mw_shl_code] Не паникуйте сейчас, согласно моему многолетнему опыту веб-разработки, программист другой стороны должен оценить реферер, очень просто, скопируйте все заголовки прошлого запроса. [mw_shl_code=java,true]def getLucky(id): #抽奖程序 print u"--- нарисовать красную конверт из:"+str(id)+"---" print "----------......----------" if checkValue(id)==False: #不符合条件, это функция return later 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, как Gecko) Chrome/33.0.1750.146 BIDUBrowser/6.x Safari/537.36', 'X-Requested-With':'XMLHttpRequest' } res = postData(luckyURL,param, заголовок)[/mw_shl_code] В этом случае теоретической проблемы нет, но на самом деле проблемы нет. После завершения лотерейного действия нужно оценить статус, и возвращаемая резолюция — это строка json, где код — 100000 успешен, а если 90114 — это верхний предел сегодняшней лотереи, и остальные значения тоже не выполняются, так что: [mw_shl_code=java,true]hbRes=json.loads(res)if hbRes["code"]=='901114': #今天红包已经抢完 print u"--------- достиг верхнего предела---------" print "----------......----------" log('lucky', str(id)+'---'+str(hbRes["code"])+'---'+hbRes["data"]["title"]) exit(0)elif hbRes["code"]=='100000':#成功 print u"---------Желаю вам процветания--------- print "----------......----------" log('success',str(id)+'---'+res) exit(0) если hbRes["data"] и hbRes["data"]["title"]: print hbRes["data"]["title"] print "----------......----------" log('lucky', str(id)+'---'+str(hbRes["код"])+'---'+hbRes["data"]["title"])else: print u"---------Request error---------" print "----------......----------" log('lucky', str(id)+'---'+res)[/mw_shl_code], где log также является функцией, которую я настраиваю, которая используется для записи журналов: [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]
|