diff --git a/jd_opencardH0208.py b/jd_opencardH0208.py new file mode 100644 index 0000000..33f0784 --- /dev/null +++ b/jd_opencardH0208.py @@ -0,0 +1,636 @@ +#!/usr/bin/env python3 +# -*- coding: utf-8 -*- + +""" +File: jd_opencardH0208.py(2.8-2.15 心意之选 为挚爱献礼) +Author: HarbourJ +Date: 2023/2/8 00:00 +TG: https://t.me/HarbourToulu +cron: 7 7 7 7 7 +new Env('2.8-2.15 心意之选 为挚爱献礼(金币)'); +ActivityEntry: https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/activity?activityId=25fee1e103434b66bb109d2042e673cb +""" + +import time, requests, sys, re, os, json, random +from datetime import datetime +from urllib.parse import quote_plus, unquote_plus +from functools import partial +print = partial(print, flush=True) +import warnings +warnings.filterwarnings("ignore", category=DeprecationWarning) +try: + from jd_sign import * +except ImportError as e: + print(e) + if "No module" in str(e): + print("请先运行HarbourJ库依赖一键安装脚本(jd_check_dependent.py),安装jd_sign.so依赖") + sys.exit() +try: + from jdCookie import get_cookies + getCk = get_cookies() +except: + print("请先下载依赖脚本,\n下载链接: https://raw.githubusercontent.com/HarbourJ/HarbourToulu/main/jdCookie.py") + sys.exit(3) + +redis_url = os.environ.get("redis_url") if os.environ.get("redis_url") else "172.17.0.1" +redis_port = os.environ.get("redis_port") if os.environ.get("redis_port") else "6379" +redis_pwd = os.environ.get("redis_pwd") if os.environ.get("redis_pwd") else "" +inviterUuid = os.environ.get("jd_joinCommon_uuid") if os.environ.get("jd_joinCommon_uuid") else "" + +activityId = "25fee1e103434b66bb109d2042e673cb" +shopId = "1000428684" +activity_url = f"https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/5929859?activityId={activityId}&shareUuid={inviterUuid}&adsource=null&shareuserid4minipg=null&lng=00.000000&lat=00.000000&sid=&un_area=&&shopid={shopId}" +print(f"【🛳活动入口】https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/5929859?activityId={activityId}\n\n🤖本活动为金币邀请,仅开卡与加购,不邀请‼️\n\n🤖本活动为金币邀请,仅开卡与加购,不邀请‼️\n\n🤖本活动为金币邀请,仅开卡与加购,不邀请‼️\n\n") + +def redis_conn(): + try: + import redis + try: + pool = redis.ConnectionPool(host=redis_url, port=redis_port, decode_responses=True, socket_connect_timeout=5, password=redis_pwd) + r = redis.Redis(connection_pool=pool) + r.get('conn_test') + print('✅redis连接成功') + return r + except: + print("⚠️redis连接异常") + except: + print("⚠️缺少redis依赖,请运行pip3 install redis") + sys.exit() + +def getToken(ck, r=None): + host = f'{activityUrl.split("com/")[0]}com' + try: + pt_pin = unquote_plus(re.compile(r'pt_pin=(.*?);').findall(ck)[0]) + except: + pt_pin = ck[:15] + try: + try: + Token = r.get(f'{activityUrl.split("https://")[1].split("-")[0]}_{pt_pin}') + except Exception as e: + # print(f"redis get error: {str(e)}") + Token = None + if Token is not None: + print(f"♻️获取缓存Token") + return Token + else: + s.headers = { + 'Connection': 'keep-alive', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8', + 'User-Agent': '', + 'Cookie': ck, + 'Host': 'api.m.jd.com', + 'Referer': '', + 'Accept-Language': 'zh-Hans-CN;q=1 en-CN;q=0.9', + 'Accept': '*/*' + } + sign({"url": f"{host}", "id": ""}, 'isvObfuscator') + f = s.post('https://api.m.jd.com/client.action', verify=False, timeout=30) + if f.status_code != 200: + print(f.status_code) + return + else: + if "参数异常" in f.text: + print(f.text) + return + Token_new = f.json()['token'] + try: + if r.set(f'{activityUrl.split("https://")[1].split("-")[0]}_{pt_pin}', Token_new, ex=1800): + print("✅Token缓存成功") + else: + print("❌Token缓存失败") + except Exception as e: + # print(f"redis set error: {str(e)}") + print(f"✅获取实时Token") + return Token_new + except Exception as e: + print(f"Token error: {str(e)}") + return + +def getJdTime(): + jdTime = int(round(time.time() * 1000)) + return jdTime + +def randomString(e, flag=False): + t = "0123456789abcdef" + if flag: t = t.upper() + n = [random.choice(t) for _ in range(e)] + return ''.join(n) + +def refresh_cookies(res): + if res.cookies: + cookies = res.cookies.get_dict() + set_cookie = [(set_cookie + "=" + cookies[set_cookie]) for set_cookie in cookies] + global activityCookie + activityCookieMid = [i for i in activityCookie.split(';') if i != ''] + for i in activityCookieMid: + for x in set_cookie: + if i.split('=')[0] == x.split('=')[0]: + if i.split('=')[1] != x.split('=')[1]: + activityCookieMid.remove(i) + activityCookie = ''.join(sorted([(set_cookie + ";") for set_cookie in list(set(activityCookieMid + set_cookie))])) + +def getActivity(): + url = activityUrl + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', + 'User-Agent': ua, + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Connection': 'keep-alive' + } + + response = requests.request("GET", url, headers=headers) + if response.status_code == 200: + if response.cookies: + cookies = response.cookies.get_dict() + set_cookies = [(set_cookie + "=" + cookies[set_cookie]) for set_cookie in cookies] + set_cookie = ''.join(sorted([(set_cookie + ";") for set_cookie in set_cookies])) + return set_cookie + else: + print(response.status_code, "⚠️ip疑似黑了,休息一会再来撸~") + sys.exit() + +def getSystemConfigForNew(): + url = "https://lzdz1-isv.isvjcloud.com/wxCommonInfo/getSystemConfigForNew" + payload = f'activityId={activityId}&activityType=99' + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def getSimpleActInfoVo(): + url = "https://lzdz1-isv.isvjcloud.com/dz/common/getSimpleActInfoVo" + payload = f"activityId={activityId}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + +def getMyPing(index, venderId): + url = "https://lzdz1-isv.isvjcloud.com/customer/getMyPing" + payload = f"userId={venderId}&token={token}&fromType=APP" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data']['nickname'], res['data']['secretPin'] + else: + print(f"⚠️{res['errorMessage']}") + if index == 1 and "火爆" in res['errorMessage']: + print(f"\t⛈车头黑,暂时不退出本程序!帮船长跑一下吧😆") + # sys.exit() + +def accessLogWithAD(venderId, pin): + url = "https://lzdz1-isv.isvjcloud.com/common/accessLogWithAD" + payload = f"venderId={venderId}&code=99&pin={quote_plus(pin)}&activityId={activityId}&pageUrl={quote_plus(activityUrl)}&subType=app&adSource=null" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def getSystime(): + url = "https://lzdz1-isv.isvjcloud.com/common/getSystime" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'Accept-Encoding': 'gzip, deflate, br', + 'Cookie': activityCookie, + 'Content-Length': '0', + 'Connection': 'keep-alive', + 'Accept': 'application/json', + 'User-Agent': ua, + 'Referer': activityUrl, + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'X-Requested-With': 'XMLHttpRequest' + } + response = requests.request("POST", url, headers=headers) + refresh_cookies(response) + +def getUserInfo(pin): + url = "https://lzdz1-isv.isvjcloud.com/wxActionCommon/getUserInfo" + payload = f"pin={quote_plus(pin)}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data']['nickname'], res['data']['yunMidImageUrl'], res['data']['pin'] + else: + print(res['errorMessage']) + +def activityContent(pin, pinImg, nickname): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activityContent" + try: + yunMidImageUrl = quote_plus(pinImg) + except: + yunMidImageUrl = quote_plus("https://img10.360buyimg.com/imgzone/jfs/t1/21383/2/6633/3879/5c5138d8E0967ccf2/91da57c5e2166005.jpg") + payload = f"activityId={activityId}&pin={quote_plus(pin)}&pinImg={yunMidImageUrl}&nick={quote_plus(nickname)}&cjyxPin=&cjhyPin=&shareUuid={shareUuid}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': f'IsvToken={token};{activityCookie}' + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + if "活动已结束" in res['errorMessage']: + sys.exit() + +def shareRecord(pin, actorUuid): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/shareRecord" + payload = f"activityId={activityId}&pin={quote_plus(pin)}&uuid={actorUuid}&num=30" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def taskRecord(pin, actorUuid): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/taskRecord" + payload = f"activityId={activityId}&pin={quote_plus(pin)}&uuid={actorUuid}&taskType=" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def drawContent(actorUuid, pin): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/taskact/common/drawContent" + payload = f"activityId={actorUuid}&pin={quote_plus(pin)}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + requests.request("POST", url, headers=headers, data=payload) + +def taskInfo(pin): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/taskInfo" + payload = f"activityId={activityId}&pin={quote_plus(pin)}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + +def assist(pin, uuid): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/assist" + payload = f"activityId={activityId}&pin={quote_plus(pin)}&uuid={uuid}&shareUuid={shareUuid}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + +def doTask(actorUuid, pin, taskType): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/doTask" + payload = f"activityId={activityId}&uuid={actorUuid}&pin={quote_plus(pin)}&taskType={taskType}&taskValue=" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + res = response.json() + print('doTask', res) + if res['result']: + data = res['data'] + if data['score'] == 0: + print("\t获得 💨💨💨") + else: + print(f"\t🎉获得{data['score']}积分") + else: + print(res['errorMessage']) + +def bindWithVender(cookie, venderId): + try: + s.headers = { + 'Connection': 'keep-alive', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8', + 'User-Agent': ua, + 'Cookie': cookie, + 'Host': 'api.m.jd.com', + 'Referer': 'https://shopmember.m.jd.com/', + 'Accept-Language': 'zh-Hans-CN;q=1 en-CN;q=0.9', + 'Accept': '*/*' + } + s.params = { + 'appid': 'jd_shop_member', + 'functionId': 'bindWithVender', + 'body': json.dumps({ + 'venderId': venderId, + 'shopId': venderId, + 'bindByVerifyCodeFlag': 1 + }, separators=(',', ':')) + } + res = s.post('https://api.m.jd.com/', verify=False, timeout=30).json() + if res['success']: + return res['message'] + except Exception as e: + print(e) + +def getShopOpenCardInfo(cookie, venderId): + shopcard_url0 = f"https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/7854908?activityId={activityId}&shareUuid={shareUuid}" + shopcard_url = f"https://shopmember.m.jd.com/shopcard/?venderId={venderId}&channel=401&returnUrl={quote_plus(shopcard_url0)}" + try: + body = {"venderId": str(venderId), "channel": "401"} + url = f'https://api.m.jd.com/client.action?appid=jd_shop_member&functionId=getShopOpenCardInfo&body={json.dumps(body)}&client=H5&clientVersion=9.2.0&uuid=88888' + headers = { + 'Host': 'api.m.jd.com', + 'Accept': '*/*', + 'Connection': 'keep-alive', + 'Cookie': cookie, + 'User-Agent': ua, + 'Accept-Language': 'zh-cn', + 'Referer': shopcard_url, + 'Accept-Encoding': 'gzip, deflate' + } + response = requests.get(url=url, headers=headers, timeout=5).text + res = json.loads(response) + if res['success']: + venderCardName = res['result']['shopMemberCardInfo']['venderCardName'] + return venderCardName + else: + return venderId + except: + return venderId + + +if __name__ == '__main__': + r = redis_conn() + try: + cks = getCk + if not cks: + sys.exit() + except: + print("未获取到有效COOKIE,退出程序!") + sys.exit() + global shareUuid, inviteSuccNum, activityUrl, firstCk + inviteSuccNum = 0 + shareUuid = remote_redis(f"lzdz1_{activityId}", 2) + activityUrl = f"https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/5929859?activityId={activityId}&shareUuid={shareUuid}&adsource=null&shareuserid4minipg=null&lng=00.000000&lat=00.000000&sid=&un_area=&&shopid={shopId}" + num = 0 + for cookie in cks: + num += 1 + if num == 1: + firstCk = cookie + if num % 10 == 0: + print("⏰等待10s,休息一下") + time.sleep(6) + global ua, activityCookie, token + ua = userAgent() + try: + pt_pin = re.compile(r'pt_pin=(.*?);').findall(cookie)[0] + pt_pin = unquote_plus(pt_pin) + except IndexError: + pt_pin = f'用户{num}' + print(f'\n******开始【京东账号{num}】{pt_pin} *********\n') + print(datetime.now()) + + token = getToken(cookie, r) + if token is None: + if num == 1: + print(f"⚠️车头获取Token失败,退出本程序!") + sys.exit() + print(f"⚠️获取Token失败!⏰等待3s") + time.sleep(3) + continue + time.sleep(0.5) + activityCookie = getActivity() + time.sleep(0.5) + getSystemConfigForNew() + time.sleep(0.3) + getSimAct = getSimpleActInfoVo() + if getSimAct: + venderId = getSimAct['venderId'] + else: + venderId = shopId + time.sleep(0.2) + getPin = getMyPing(num, venderId) + if getPin is not None: + nickname = getPin[0] + secretPin = getPin[1] + time.sleep(0.5) + accessLogWithAD(venderId, secretPin) + time.sleep(0.5) + userInfo = getUserInfo(secretPin) + time.sleep(0.8) + nickname = userInfo[0] + yunMidImageUrl = userInfo[1] + pin = userInfo[2] + actContent = activityContent(pin, yunMidImageUrl, nickname) + if not actContent: + if num == 1: + print("⚠️无法获取车头邀请码,退出本程序!") + sys.exit() + continue + hasEnd = actContent['hasEnd'] + if hasEnd: + print("活动已结束,下次早点来~") + sys.exit() + print(f"✅开启【{actContent['activityName']}】活动\n") + actorUuid = actContent['actorInfo']['uuid'] + taskType = actContent['taskType'] + time.sleep(0.5) + shareRecord(pin, actorUuid) + time.sleep(0.5) + taskRecord(pin, actorUuid) + time.sleep(0.5) + print("现在去一键关注店铺") + doTask(actorUuid, pin, 20) + time.sleep(1) + doTask(actorUuid, pin, 23) + time.sleep(1) + ass0 = assist(pin, actorUuid) + assistState0 = ass0['assistState'] + openAll0 = ass0['openCardInfo']['openAll'] + openVenderId0 = ass0['openCardInfo']['openVenderId'] + assStat = False + if openAll0: + print("已完成全部开卡任务") + if assistState0 == 0: + print("已经助力过你~") + # elif assistState0 == 0: + # print("无法助力自己~") + elif assistState0 == 3: + print("已助力过其他好友~") + elif assistState0 == 1: + print("已完成开卡关注任务,未助力过好友~") + assStat = True + else: + # print('assistStatus:', assistState0) + assStat = True + else: + print("现在去开卡") + task_info0 = taskInfo(pin) + openCardList = task_info0['1']['settingInfo'] + openCardLists = [(int(i['value']), i['name']) for i in openCardList] + unOpenCardLists = [i for i in openCardLists if i[0] not in openVenderId0] + for shop in unOpenCardLists: + print(f"去开卡 {shop[0]}") + venderId = shop[0] + venderCardName = shop[1] + getShopOpenCardInfo(cookie, venderId) + open_result = bindWithVender(cookie, venderId) + if open_result is not None: + if "火爆" in open_result or "失败" in open_result or "解绑" in open_result: + print(f"\t⛈⛈{venderCardName} {open_result}") + assStat = False + break + else: + print(f"\t🎉🎉{venderCardName} {open_result}") + assStat = True + time.sleep(1.5) + activityContent(pin, yunMidImageUrl, nickname) + shareRecord(pin, actorUuid) + time.sleep(0.5) + taskRecord(pin, actorUuid) + time.sleep(0.5) + ass1 = assist(pin, actorUuid) + assistState1 = ass1['assistState'] + if assStat and assistState1 == 1: + pass + + time.sleep(3) \ No newline at end of file diff --git a/jd_opencardH0220.py b/jd_opencardH0220.py new file mode 100644 index 0000000..c4a25cd --- /dev/null +++ b/jd_opencardH0220.py @@ -0,0 +1,636 @@ +#!/usr/bin/env python3 +# -*- coding: utf-8 -*- + +""" +File: jd_opencardH0210.py(2.10-2.17 心动二月 为爱献礼) +Author: HarbourJ +Date: 2023/2/10 00:00 +TG: https://t.me/HarbourToulu +cron: 7 7 7 7 7 +new Env('2.10-2.17 心动二月 为爱献礼(金币)'); +ActivityEntry: https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/activity?activityId=92bbca6be5174058bb6896e4fa689b07 +""" + +import time, requests, sys, re, os, json, random +from datetime import datetime +from urllib.parse import quote_plus, unquote_plus +from functools import partial +print = partial(print, flush=True) +import warnings +warnings.filterwarnings("ignore", category=DeprecationWarning) +try: + from jd_sign import * +except ImportError as e: + print(e) + if "No module" in str(e): + print("请先运行HarbourJ库依赖一键安装脚本(jd_check_dependent.py),安装jd_sign.so依赖") + sys.exit() +try: + from jdCookie import get_cookies + getCk = get_cookies() +except: + print("请先下载依赖脚本,\n下载链接: https://raw.githubusercontent.com/HarbourJ/HarbourToulu/main/jdCookie.py") + sys.exit(3) + +redis_url = os.environ.get("redis_url") if os.environ.get("redis_url") else "172.17.0.1" +redis_port = os.environ.get("redis_port") if os.environ.get("redis_port") else "6379" +redis_pwd = os.environ.get("redis_pwd") if os.environ.get("redis_pwd") else "" +inviterUuid = os.environ.get("jd_joinCommon_uuid") if os.environ.get("jd_joinCommon_uuid") else "" + +activityId = "92bbca6be5174058bb6896e4fa689b07" +shopId = "1000428684" +activity_url = f"https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/5929859?activityId={activityId}&shareUuid={inviterUuid}&adsource=null&shareuserid4minipg=null&lng=00.000000&lat=00.000000&sid=&un_area=&&shopid={shopId}" +print(f"【🛳活动入口】https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/5929859?activityId={activityId}\n\n🤖本活动为金币邀请,仅开卡与加购,不邀请‼️\n\n🤖本活动为金币邀请,仅开卡与加购,不邀请‼️\n\n🤖本活动为金币邀请,仅开卡与加购,不邀请‼️\n\n") + +def redis_conn(): + try: + import redis + try: + pool = redis.ConnectionPool(host=redis_url, port=redis_port, decode_responses=True, socket_connect_timeout=5, password=redis_pwd) + r = redis.Redis(connection_pool=pool) + r.get('conn_test') + print('✅redis连接成功') + return r + except: + print("⚠️redis连接异常") + except: + print("⚠️缺少redis依赖,请运行pip3 install redis") + sys.exit() + +def getToken(ck, r=None): + host = f'{activityUrl.split("com/")[0]}com' + try: + pt_pin = unquote_plus(re.compile(r'pt_pin=(.*?);').findall(ck)[0]) + except: + pt_pin = ck[:15] + try: + try: + Token = r.get(f'{activityUrl.split("https://")[1].split("-")[0]}_{pt_pin}') + except Exception as e: + # print(f"redis get error: {str(e)}") + Token = None + if Token is not None: + print(f"♻️获取缓存Token") + return Token + else: + s.headers = { + 'Connection': 'keep-alive', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8', + 'User-Agent': '', + 'Cookie': ck, + 'Host': 'api.m.jd.com', + 'Referer': '', + 'Accept-Language': 'zh-Hans-CN;q=1 en-CN;q=0.9', + 'Accept': '*/*' + } + sign({"url": f"{host}", "id": ""}, 'isvObfuscator') + f = s.post('https://api.m.jd.com/client.action', verify=False, timeout=30) + if f.status_code != 200: + print(f.status_code) + return + else: + if "参数异常" in f.text: + print(f.text) + return + Token_new = f.json()['token'] + try: + if r.set(f'{activityUrl.split("https://")[1].split("-")[0]}_{pt_pin}', Token_new, ex=1800): + print("✅Token缓存成功") + else: + print("❌Token缓存失败") + except Exception as e: + # print(f"redis set error: {str(e)}") + print(f"✅获取实时Token") + return Token_new + except Exception as e: + print(f"Token error: {str(e)}") + return + +def getJdTime(): + jdTime = int(round(time.time() * 1000)) + return jdTime + +def randomString(e, flag=False): + t = "0123456789abcdef" + if flag: t = t.upper() + n = [random.choice(t) for _ in range(e)] + return ''.join(n) + +def refresh_cookies(res): + if res.cookies: + cookies = res.cookies.get_dict() + set_cookie = [(set_cookie + "=" + cookies[set_cookie]) for set_cookie in cookies] + global activityCookie + activityCookieMid = [i for i in activityCookie.split(';') if i != ''] + for i in activityCookieMid: + for x in set_cookie: + if i.split('=')[0] == x.split('=')[0]: + if i.split('=')[1] != x.split('=')[1]: + activityCookieMid.remove(i) + activityCookie = ''.join(sorted([(set_cookie + ";") for set_cookie in list(set(activityCookieMid + set_cookie))])) + +def getActivity(): + url = activityUrl + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', + 'User-Agent': ua, + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Connection': 'keep-alive' + } + + response = requests.request("GET", url, headers=headers) + if response.status_code == 200: + if response.cookies: + cookies = response.cookies.get_dict() + set_cookies = [(set_cookie + "=" + cookies[set_cookie]) for set_cookie in cookies] + set_cookie = ''.join(sorted([(set_cookie + ";") for set_cookie in set_cookies])) + return set_cookie + else: + print(response.status_code, "⚠️ip疑似黑了,休息一会再来撸~") + sys.exit() + +def getSystemConfigForNew(): + url = "https://lzdz1-isv.isvjcloud.com/wxCommonInfo/getSystemConfigForNew" + payload = f'activityId={activityId}&activityType=99' + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def getSimpleActInfoVo(): + url = "https://lzdz1-isv.isvjcloud.com/dz/common/getSimpleActInfoVo" + payload = f"activityId={activityId}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + +def getMyPing(index, venderId): + url = "https://lzdz1-isv.isvjcloud.com/customer/getMyPing" + payload = f"userId={venderId}&token={token}&fromType=APP" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data']['nickname'], res['data']['secretPin'] + else: + print(f"⚠️{res['errorMessage']}") + if index == 1 and "火爆" in res['errorMessage']: + print(f"\t⛈车头黑,暂时不退出本程序!帮船长跑一下吧😆") + # sys.exit() + +def accessLogWithAD(venderId, pin): + url = "https://lzdz1-isv.isvjcloud.com/common/accessLogWithAD" + payload = f"venderId={venderId}&code=99&pin={quote_plus(pin)}&activityId={activityId}&pageUrl={quote_plus(activityUrl)}&subType=app&adSource=null" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def getSystime(): + url = "https://lzdz1-isv.isvjcloud.com/common/getSystime" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'Accept-Encoding': 'gzip, deflate, br', + 'Cookie': activityCookie, + 'Content-Length': '0', + 'Connection': 'keep-alive', + 'Accept': 'application/json', + 'User-Agent': ua, + 'Referer': activityUrl, + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'X-Requested-With': 'XMLHttpRequest' + } + response = requests.request("POST", url, headers=headers) + refresh_cookies(response) + +def getUserInfo(pin): + url = "https://lzdz1-isv.isvjcloud.com/wxActionCommon/getUserInfo" + payload = f"pin={quote_plus(pin)}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data']['nickname'], res['data']['yunMidImageUrl'], res['data']['pin'] + else: + print(res['errorMessage']) + +def activityContent(pin, pinImg, nickname): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activityContent" + try: + yunMidImageUrl = quote_plus(pinImg) + except: + yunMidImageUrl = quote_plus("https://img10.360buyimg.com/imgzone/jfs/t1/21383/2/6633/3879/5c5138d8E0967ccf2/91da57c5e2166005.jpg") + payload = f"activityId={activityId}&pin={quote_plus(pin)}&pinImg={yunMidImageUrl}&nick={quote_plus(nickname)}&cjyxPin=&cjhyPin=&shareUuid={shareUuid}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': f'IsvToken={token};{activityCookie}' + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + if "活动已结束" in res['errorMessage']: + sys.exit() + +def shareRecord(pin, actorUuid): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/shareRecord" + payload = f"activityId={activityId}&pin={quote_plus(pin)}&uuid={actorUuid}&num=30" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def taskRecord(pin, actorUuid): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/taskRecord" + payload = f"activityId={activityId}&pin={quote_plus(pin)}&uuid={actorUuid}&taskType=" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + refresh_cookies(response) + +def drawContent(actorUuid, pin): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/taskact/common/drawContent" + payload = f"activityId={actorUuid}&pin={quote_plus(pin)}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + requests.request("POST", url, headers=headers, data=payload) + +def taskInfo(pin): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/taskInfo" + payload = f"activityId={activityId}&pin={quote_plus(pin)}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + +def assist(pin, uuid): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/assist" + payload = f"activityId={activityId}&pin={quote_plus(pin)}&uuid={uuid}&shareUuid={shareUuid}" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + res = response.json() + if res['result']: + return res['data'] + else: + print(res['errorMessage']) + +def doTask(actorUuid, pin, taskType): + url = "https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/doTask" + payload = f"activityId={activityId}&uuid={actorUuid}&pin={quote_plus(pin)}&taskType={taskType}&taskValue=" + headers = { + 'Host': 'lzdz1-isv.isvjcloud.com', + 'Accept': 'application/json', + 'X-Requested-With': 'XMLHttpRequest', + 'Accept-Language': 'zh-CN,zh-Hans;q=0.9', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded', + 'Origin': 'https://lzdz1-isv.isvjcloud.com', + 'User-Agent': ua, + 'Connection': 'keep-alive', + 'Referer': activityUrl, + 'Cookie': activityCookie + } + response = requests.request("POST", url, headers=headers, data=payload) + res = response.json() + print('doTask', res) + if res['result']: + data = res['data'] + if data['score'] == 0: + print("\t获得 💨💨💨") + else: + print(f"\t🎉获得{data['score']}积分") + else: + print(res['errorMessage']) + +def bindWithVender(cookie, venderId): + try: + s.headers = { + 'Connection': 'keep-alive', + 'Accept-Encoding': 'gzip, deflate, br', + 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8', + 'User-Agent': ua, + 'Cookie': cookie, + 'Host': 'api.m.jd.com', + 'Referer': 'https://shopmember.m.jd.com/', + 'Accept-Language': 'zh-Hans-CN;q=1 en-CN;q=0.9', + 'Accept': '*/*' + } + s.params = { + 'appid': 'jd_shop_member', + 'functionId': 'bindWithVender', + 'body': json.dumps({ + 'venderId': venderId, + 'shopId': venderId, + 'bindByVerifyCodeFlag': 1 + }, separators=(',', ':')) + } + res = s.post('https://api.m.jd.com/', verify=False, timeout=30).json() + if res['success']: + return res['message'] + except Exception as e: + print(e) + +def getShopOpenCardInfo(cookie, venderId): + shopcard_url0 = f"https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/7854908?activityId={activityId}&shareUuid={shareUuid}" + shopcard_url = f"https://shopmember.m.jd.com/shopcard/?venderId={venderId}&channel=401&returnUrl={quote_plus(shopcard_url0)}" + try: + body = {"venderId": str(venderId), "channel": "401"} + url = f'https://api.m.jd.com/client.action?appid=jd_shop_member&functionId=getShopOpenCardInfo&body={json.dumps(body)}&client=H5&clientVersion=9.2.0&uuid=88888' + headers = { + 'Host': 'api.m.jd.com', + 'Accept': '*/*', + 'Connection': 'keep-alive', + 'Cookie': cookie, + 'User-Agent': ua, + 'Accept-Language': 'zh-cn', + 'Referer': shopcard_url, + 'Accept-Encoding': 'gzip, deflate' + } + response = requests.get(url=url, headers=headers, timeout=5).text + res = json.loads(response) + if res['success']: + venderCardName = res['result']['shopMemberCardInfo']['venderCardName'] + return venderCardName + else: + return venderId + except: + return venderId + + +if __name__ == '__main__': + r = redis_conn() + try: + cks = getCk + if not cks: + sys.exit() + except: + print("未获取到有效COOKIE,退出程序!") + sys.exit() + global shareUuid, inviteSuccNum, activityUrl, firstCk + inviteSuccNum = 0 + shareUuid = remote_redis(f"lzdz1_{activityId}", 2) + activityUrl = f"https://lzdz1-isv.isvjcloud.com/dingzhi/joinCommon/activity/5929859?activityId={activityId}&shareUuid={shareUuid}&adsource=null&shareuserid4minipg=null&lng=00.000000&lat=00.000000&sid=&un_area=&&shopid={shopId}" + num = 0 + for cookie in cks: + num += 1 + if num == 1: + firstCk = cookie + if num % 10 == 0: + print("⏰等待10s,休息一下") + time.sleep(6) + global ua, activityCookie, token + ua = userAgent() + try: + pt_pin = re.compile(r'pt_pin=(.*?);').findall(cookie)[0] + pt_pin = unquote_plus(pt_pin) + except IndexError: + pt_pin = f'用户{num}' + print(f'\n******开始【京东账号{num}】{pt_pin} *********\n') + print(datetime.now()) + + token = getToken(cookie, r) + if token is None: + if num == 1: + print(f"⚠️车头获取Token失败,退出本程序!") + sys.exit() + print(f"⚠️获取Token失败!⏰等待3s") + time.sleep(3) + continue + time.sleep(0.5) + activityCookie = getActivity() + time.sleep(0.5) + getSystemConfigForNew() + time.sleep(0.3) + getSimAct = getSimpleActInfoVo() + if getSimAct: + venderId = getSimAct['venderId'] + else: + venderId = shopId + time.sleep(0.2) + getPin = getMyPing(num, venderId) + if getPin is not None: + nickname = getPin[0] + secretPin = getPin[1] + time.sleep(0.5) + accessLogWithAD(venderId, secretPin) + time.sleep(0.5) + userInfo = getUserInfo(secretPin) + time.sleep(0.8) + nickname = userInfo[0] + yunMidImageUrl = userInfo[1] + pin = userInfo[2] + actContent = activityContent(pin, yunMidImageUrl, nickname) + if not actContent: + if num == 1: + print("⚠️无法获取车头邀请码,退出本程序!") + sys.exit() + continue + hasEnd = actContent['hasEnd'] + if hasEnd: + print("活动已结束,下次早点来~") + sys.exit() + print(f"✅开启【{actContent['activityName']}】活动\n") + actorUuid = actContent['actorInfo']['uuid'] + taskType = actContent['taskType'] + time.sleep(0.5) + shareRecord(pin, actorUuid) + time.sleep(0.5) + taskRecord(pin, actorUuid) + time.sleep(0.5) + print("现在去一键关注店铺") + doTask(actorUuid, pin, 20) + time.sleep(1) + doTask(actorUuid, pin, 23) + time.sleep(1) + ass0 = assist(pin, actorUuid) + assistState0 = ass0['assistState'] + openAll0 = ass0['openCardInfo']['openAll'] + openVenderId0 = ass0['openCardInfo']['openVenderId'] + assStat = False + if openAll0: + print("已完成全部开卡任务") + if assistState0 == 0: + print("已经助力过你~") + # elif assistState0 == 0: + # print("无法助力自己~") + elif assistState0 == 3: + print("已助力过其他好友~") + elif assistState0 == 1: + print("已完成开卡关注任务,未助力过好友~") + assStat = True + else: + # print('assistStatus:', assistState0) + assStat = True + else: + print("现在去开卡") + task_info0 = taskInfo(pin) + openCardList = task_info0['1']['settingInfo'] + openCardLists = [(int(i['value']), i['name']) for i in openCardList] + unOpenCardLists = [i for i in openCardLists if i[0] not in openVenderId0] + for shop in unOpenCardLists: + print(f"去开卡 {shop[0]}") + venderId = shop[0] + venderCardName = shop[1] + getShopOpenCardInfo(cookie, venderId) + open_result = bindWithVender(cookie, venderId) + if open_result is not None: + if "火爆" in open_result or "失败" in open_result or "解绑" in open_result: + print(f"\t⛈⛈{venderCardName} {open_result}") + assStat = False + break + else: + print(f"\t🎉🎉{venderCardName} {open_result}") + assStat = True + time.sleep(1.5) + activityContent(pin, yunMidImageUrl, nickname) + shareRecord(pin, actorUuid) + time.sleep(0.5) + taskRecord(pin, actorUuid) + time.sleep(0.5) + ass1 = assist(pin, actorUuid) + assistState1 = ass1['assistState'] + if assStat and assistState1 == 1: + pass + + time.sleep(3) \ No newline at end of file