diff --git a/jd_try_notify.py b/jd_try_notify.py deleted file mode 100644 index 8013483..0000000 --- a/jd_try_notify.py +++ /dev/null @@ -1,145 +0,0 @@ - -""" -cron: 10 20 * * * -new Env('京东试用成功通知'); -""" -import requests -import json -import time -import os -import re -import sys -import random -import string -import urllib - - - -def randomuserAgent(): - global uuid,addressid,iosVer,iosV,clientVersion,iPhone,area,ADID,lng,lat - uuid=''.join(random.sample(['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','0','1','2','3','4','5','6','7','8','9','a','b','c','z'], 40)) - addressid = ''.join(random.sample('1234567898647', 10)) - iosVer = ''.join(random.sample(["15.1.1","14.5.1", "14.4", "14.3", "14.2", "14.1", "14.0.1"], 1)) - iosV = iosVer.replace('.', '_') - clientVersion=''.join(random.sample(["10.3.0", "10.2.7", "10.2.4"], 1)) - iPhone = ''.join(random.sample(["8", "9", "10", "11", "12", "13"], 1)) - area=''.join(random.sample('0123456789', 2)) + '_' + ''.join(random.sample('0123456789', 4)) + '_' + ''.join(random.sample('0123456789', 5)) + '_' + ''.join(random.sample('0123456789', 4)) - ADID = ''.join(random.sample('0987654321ABCDEF', 8)) + '-' + ''.join(random.sample('0987654321ABCDEF', 4)) + '-' + ''.join(random.sample('0987654321ABCDEF', 4)) + '-' + ''.join(random.sample('0987654321ABCDEF', 4)) + '-' + ''.join(random.sample('0987654321ABCDEF', 12)) - lng='119.31991256596'+str(random.randint(100,999)) - lat='26.1187118976'+str(random.randint(100,999)) - UserAgent='' - if not UserAgent: - return f'jdapp;iPhone;10.0.4;{iosVer};{uuid};network/wifi;ADID/{ADID};model/iPhone{iPhone},1;addressid/{addressid};appBuild/167707;jdSupportDarkMode/0;Mozilla/5.0 (iPhone; CPU iPhone OS {iosV} like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/null;supportJDSHWK/1' - else: - return UserAgent - -#以上部分参考Curtin的脚本:https://github.com/curtinlv/JD-Script - -def load_send(): - global send - cur_path = os.path.abspath(os.path.dirname(__file__)) - sys.path.append(cur_path) - if os.path.exists(cur_path + "/sendNotify.py"): - try: - from sendNotify import send - except: - send=False - print("加载通知服务失败~") - else: - send=False - print("加载通知服务失败~") -load_send() - - -def printf(text): - print(text) - sys.stdout.flush() - -def get_remarkinfo(): - url='http://127.0.0.1:5600/api/envs' - try: - path = '/ql/config/auth.json' # 设置青龙 auth文件地址 - if not os.path.isfile(path): - path = '/ql/data/config/auth.json' # 尝试设置青龙 auth 新版文件地址 - if os.path.isfile(path): # 进行文件真值判断 - with open(path, "r") as file: # 上下文管理 - auth = file.read() # 读取文件 - file.close() # 关闭文件 - auth = json.loads(auth) # 使用 json模块读取 - # with open('/ql/config/auth.json', 'r') as f: - # token=json.loads(f.read())['token'] - token = auth["token"] # 提取 authkey - headers={ - 'Accept':'application/json', - 'authorization':'Bearer '+token, - } - response=requests.get(url=url,headers=headers) - - for i in range(len(json.loads(response.text)['data'])): - if json.loads(response.text)['data'][i]['name']=='JD_COOKIE': - try: - if json.loads(response.text)['data'][i]['remarks'].find('@@')==-1: - remarkinfos[json.loads(response.text)['data'][i]['value'].split(';')[1].replace('pt_pin=','')]=json.loads(response.text)['data'][i]['remarks'].replace('remark=','') - else: - remarkinfos[json.loads(response.text)['data'][i]['value'].split(';')[1].replace('pt_pin=','')]=json.loads(response.text)['data'][i]['remarks'].split("@@")[0].replace('remark=','').replace(';','') - except: - pass - except: - print('读取auth.json文件出错,跳过获取备注') - -def get_succeedinfo(ck): - jda = "__jda=1.1.1.1.1;" - url='https://api.m.jd.com/client.action' - headers={ - 'accept':'application/json, text/plain, */*', - 'content-type':'application/x-www-form-urlencoded', - 'origin':'https://prodev.m.jd.com', - 'accept-language':'zh-CN,zh-Hans;q=0.9', - 'User-Agent': UserAgent, - 'referer':'https://prodev.m.jd.com/', - 'accept-encoding':'gzip, deflate', - 'cookie': ck + jda - } - data=f'appid=newtry&functionId=try_MyTrials&uuid={uuid}&clientVersion={clientVersion}&client=wh5&osVersion={iosVer}&area={area}&networkType=wifi&body=%7B%22page%22%3A1%2C%22selected%22%3A2%2C%22previewTime%22%3A%22%22%7D' - response=requests.post(url=url,headers=headers,data=data) - isnull=True - try: - for i in range(len(json.loads(response.text)['data']['list'])): - if(json.loads(response.text)['data']['list'][i]['text']['text']).find('试用资格将保留')!=-1: - print(json.loads(response.text)['data']['list'][i]['trialName']) - try: - send("京东试用待领取物品通知",'账号名称:'+remarkinfos[ptpin]+'\n'+'商品名称:'+json.loads(response.text)['data']['list'][i]['trialName']+"\n"+"商品链接:https://item.jd.com/"+json.loads(response.text)['data']['list'][i]['skuId']+".html") - isnull=False - except: - send("京东试用待领取物品通知",'账号名称:'+urllib.parse.unquote(ptpin)+'\n'+'商品名称:'+json.loads(response.text)['data']['list'][i]['trialName']+"\n"+"商品链接:https://item.jd.com/"+json.loads(response.text)['data']['list'][i]['skuId']+".html") - isnull=False - if isnull==True: - print("没有在有效期内待领取的试用品\n\n") - except: - print('获取信息出错,可能是账号已过期') -if __name__ == '__main__': - remarkinfos={} - try: - get_remarkinfo() - except: - pass - try: - cks = os.environ["JD_COOKIE"].split("&") - except: - f = open("/jd/config/config.sh", "r", encoding='utf-8') - cks = re.findall(r'Cookie[0-9]*="(pt_key=.*?;pt_pin=.*?;)"', f.read()) - f.close() - for ck in cks: - ck = ck.strip() - if ck[-1] != ';': - ck += ';' - ptpin = re.findall(r"pt_pin=(.*?);", ck)[0] - try: - if remarkinfos[ptpin]!='': - printf("--账号:" + remarkinfos[ptpin] + "--") - else: - printf("--无备注账号:" + urllib.parse.unquote(ptpin) + "--") - except Exception as e: - printf("--账号:" + urllib.parse.unquote(ptpin) + "--") - UserAgent=randomuserAgent() - get_succeedinfo(ck) \ No newline at end of file