DDR爱好者之家 Design By 杰米
本文实例为大家分享了python实现QQ空间自动点赞的具体代码,供大家参考,具体内容如下
项目github地址
使用python实现qq空间自动点赞功能。
需自行安装库并配置环境。
我想实现的是每6个小时就自动更新一次cookie。这也是和网上其他版本相比具有的优点。不用手动输入cookie。更加自动。(不负责任的说,这个功能没有测试过。)
程序运行方法:将代码存为.py文件,运行即可。
输入QQ密码的时候采用了linux登录的方式——没有回显。
from selenium import webdriver from selenium.webdriver.chrome.options import Options import time import requests import demjson import re import datetime import getpass qq = '' pwd = '' def print_time(): print(datetime.datetime.now(), end=' ') def get_gtk(p_skey): hash=5381 for i in p_skey: hash += (hash << 5)+ord(i) print_time() print('生成gtk') return hash & 0x7fffffff def change_cookie(cookie): s = '' for c in cookie: s = s + c['name'] + '=' + c['value'] + '; ' return s def check_time(): now = datetime.datetime.now() hour = str(now)[11:13] minute = str(now)[14:16] second = str(now)[17:19] if 0 == int(hour) % 6 and minute == '00' and int(second) < 30: return True else: return False def get_cookie(): chrome_options = Options() chrome_options.add_argument('--headless') driver = webdriver.Chrome(chrome_options=chrome_options) driver.get('https://qzone.qq.com/') driver.switch_to.frame('login_frame') driver.find_element_by_id('switcher_plogin').click() driver.find_element_by_id('u').clear() driver.find_element_by_id('u').send_keys(qq) driver.find_element_by_id('p').clear() driver.find_element_by_id('p').send_keys(pwd) driver.find_element_by_id('login_button').click() time.sleep(1) driver.find_element_by_id('QZ_Body').click() cookie = driver.get_cookies() # print(cookie) driver.close() driver.quit() print_time() print('提取cookie') return cookie def get_args(): cookie = get_cookie() for c in cookie: if c['name'] == 'p_skey': p_skey = c['value'] break cookie = change_cookie(cookie) # print(p_skey) gtk = get_gtk(p_skey) return cookie, gtk def do_like(d, gtk, headers): url = 'https://user.qzone.qq.com/proxy/domain/w.qzone.qq.com/cgi-bin/likes/internal_dolike_app"http:[^"]*\"', html).group(0) # curkey = re.search(r'data-curkey=\"http:[^"]*\"', html).group(0) # print(unikey, curkey) temp = re.search('data-unikey="(http[^"]*)"[^d]*data-curkey="([^"]*)"[^d]*data-clicklog=("like")[^h]*href="javascript:;" rel="external nofollow" rel="external nofollow" ', html); if temp is None: return unikey = temp.group(1); curkey = temp.group(2); # print(unikey, curkey) body['unikey'] = unikey body['curkey'] = curkey body['appid'] = d['appid'] body['typeid'] = d['typeid'] body['fid'] = d['key'] r = requests.post(url, data=body, headers=headers) if 200 == r.status_code: print_time() print('给 ' + d['nickname'] + ' 点赞') except: return def get_content(headers, gtk): try: r = requests.get('http://ic2.s8.qzone.qq.com/cgi-bin/feeds/feeds3_html_more"htmlcode">from selenium import webdriver from selenium.webdriver.chrome.options import Options from selenium.webdriver.common.action_chains import ActionChains from PIL import Image from io import BytesIO import time import requests import demjson import re import datetime import getpass qq = '' pwd = '' def print_time(): print(datetime.datetime.now(), end=' ') def get_gtk(p_skey): hash=5381 for i in p_skey: hash += (hash << 5)+ord(i) print_time() print('生成gtk') return hash & 0x7fffffff def change_cookie(cookie): s = '' for c in cookie: s = s + c['name'] + '=' + c['value'] + '; ' return s def check_time(): now = datetime.datetime.now() hour = str(now)[11:13] minute = str(now)[14:16] second = str(now)[17:19] if 0 == int(hour) % 6 and minute == '00' and int(second) < 30: return True else: return False def get_image_difference(back_img, full_img): width, height = full_img.size for w in range(0, width): for h in range(0, height): back_pixel = back_img.getpixel((w, h)) full_pixel = full_img.getpixel((w, h)) if back_pixel != full_pixel and w > 340 and h > 10 and abs(back_pixel[0]-full_pixel[0])>50 and abs(back_pixel[1]-full_pixel[1])>50 and abs(back_pixel[2]-full_pixel[2])>50: return True, w return False, -1 def get_cookie(): chrome_options = Options() chrome_options.add_argument('--headless') driver = webdriver.Chrome(chrome_options=chrome_options) driver.get('https://qzone.qq.com/') driver.switch_to.frame('login_frame') driver.find_element_by_id('switcher_plogin').click() driver.find_element_by_id('u').clear() driver.find_element_by_id('u').send_keys(qq) driver.find_element_by_id('p').clear() driver.find_element_by_id('p').send_keys(pwd) driver.find_element_by_id('login_button').click() time.sleep(3) frame = driver.find_element_by_xpath('//*[@id="newVcodeIframe"]/iframe') driver.switch_to.frame(frame) # back_url = driver.find_element_by_id('slideBkg').get_attribute('src') full_url = back_url.replace('hycdn_1', 'hycdn_0') r = requests.get(back_url) file = BytesIO(r.content) back_img = Image.open(file) r.status_code = 500 while 200 != r.status_code: r = requests.get(full_url) file = BytesIO(r.content) full_img = Image.open(file) r, w = get_image_difference(back_img, full_img) if r is False: return # print(w) # 280 * 158 # 680 * 390 # 55 * 55 # 136 * 136 # 214 slide = driver.find_element_by_id('tcaptcha_drag_thumb') ActionChains(driver).click_and_hold(slide).perform() ActionChains(driver).move_by_offset(xoffset=w / 680 * 250, yoffset=0).perform() ActionChains(driver).release(slide).perform() # print(back_img.size) # print(cut_img.size) # print(full_img.size) time.sleep(2) driver.find_element_by_id('QZ_Body').click() cookie = driver.get_cookies() # print(cookie) driver.close() driver.quit() print_time() print('提取cookie') return cookie def get_args(): cookie = get_cookie() for c in cookie: if c['name'] == 'p_skey': p_skey = c['value'] break cookie = change_cookie(cookie) # print(p_skey) gtk = get_gtk(p_skey) return cookie, gtk def do_like(d, gtk, headers): url = 'https://user.qzone.qq.com/proxy/domain/w.qzone.qq.com/cgi-bin/likes/internal_dolike_app"http:[^"]*\"', html).group(0) # curkey = re.search(r'data-curkey=\"http:[^"]*\"', html).group(0) # print(unikey, curkey) temp = re.search('data-unikey="(http[^"]*)"[^d]*data-curkey="([^"]*)"[^d]*data-clicklog=("like")[^h]*href="javascript:;" rel="external nofollow" rel="external nofollow" ', html); if temp is None: return unikey = temp.group(1); curkey = temp.group(2); # print(unikey, curkey) body['unikey'] = unikey body['curkey'] = curkey body['appid'] = d['appid'] body['typeid'] = d['typeid'] body['fid'] = d['key'] r = requests.post(url, data=body, headers=headers) if 200 == r.status_code: print_time() print('给 ' + d['nickname'] + ' 点赞') except: return def get_content(headers, gtk): try: r = requests.get('http://ic2.s8.qzone.qq.com/cgi-bin/feeds/feeds3_html_more?uin=0924761163&scope=0&view=1&daylist=&uinlist=&gid=&flag=1&filter=all&applist=all&refresh=0&aisortEndTime=0&aisortOffset=0&getAisort=0&aisortBeginTime=0&pagenum=1&externparam=offset%3D6%26total%3D97%26basetime%3D1470323193%26feedsource%3D0&firstGetGroup=0&icServerTime=0&mixnocache=0&scene=0&begintime=0&count=10&dayspac=0&sidomain=cnc.qzonestyle.gtimg.cn&useutf8=1&outputhtmlfeed=1&getob=1&g_tk=' + str(gtk), headers=headers) r = r.text[10:-2] r = demjson.decode(r) data = r['data']['data'] print_time() print('获取了 ' + str(len(data)) + ' 条说说') return data except: return [] def main(): print_time() print('程序运行...') global qq global pwd qq = input('QQ:') pwd = getpass.getpass('Password:') headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36' } cookie, gtk = get_args() headers['Cookie'] = cookie while True: time.sleep(1) if check_time(): cookie, gtk = get_args() headers['Cookie'] = cookie print_time() print('更新了 cookie 和 gtk') data = get_content(headers, gtk) for d in data: do_like(d, gtk, headers) if __name__ == '__main__': main()上面两份代码整体思路没问题,但是偶尔会有一些小bug。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月26日
2024年11月26日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]