mirror of
https://github.com/shufflewzc/faker2.git
synced 2025-04-23 02:48:44 +08:00
update
This commit is contained in:
parent
aa0069c5ce
commit
46eb7a5bee
@ -85,7 +85,9 @@ if ($.isNode()) {
|
|||||||
$.keywordsNum = 0
|
$.keywordsNum = 0
|
||||||
if ($.beforeRemove !== "0") {
|
if ($.beforeRemove !== "0") {
|
||||||
await cartFilter_xh(venderCart);
|
await cartFilter_xh(venderCart);
|
||||||
|
$.retry = 0;
|
||||||
if (parseInt($.beforeRemove) !== $.keywordsNum) await removeCart();
|
if (parseInt($.beforeRemove) !== $.keywordsNum) await removeCart();
|
||||||
|
if($.retry = 2) break;
|
||||||
else {
|
else {
|
||||||
console.log('\n由于购物车内的商品均包含关键字,本次执行将不删除购物车数据')
|
console.log('\n由于购物车内的商品均包含关键字,本次执行将不删除购物车数据')
|
||||||
break;
|
break;
|
||||||
@ -194,6 +196,7 @@ function removeCart() {
|
|||||||
console.log('删除失败')
|
console.log('删除失败')
|
||||||
console.log(data.errMsg)
|
console.log(data.errMsg)
|
||||||
$.error = true;
|
$.error = true;
|
||||||
|
$.retry++;
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
$.logErr(e, resp);
|
$.logErr(e, resp);
|
||||||
|
45
jd_dpqd.js
45
jd_dpqd.js
@ -25,31 +25,34 @@ let vender=''
|
|||||||
let num=0
|
let num=0
|
||||||
let shopname=''
|
let shopname=''
|
||||||
const token = [
|
const token = [
|
||||||
"E7C2D644F989BBA3ADB563A682E591C6",
|
"156E859B3A314171CA34B780C19CB215",
|
||||||
"1BF7556DFA8680BBCDD2F57937830BB7",
|
"35BA76ED53A953E03F77EE5379C28BE5",
|
||||||
"4BE1B58FE1360409A5967CAD1127B5A8",
|
"4BE1B58FE1360409A5967CAD1127B5A8",
|
||||||
"34864F266AFC02DDB7EEAD5A2AF9B4F7",
|
|
||||||
"7166EF6ED03BA34C3DBBA1ADB27E56C1",
|
|
||||||
"C031053EDBD2C047C072C53F80D82577",
|
|
||||||
"18FB7E1DE514D5E40D880585D4145DEC",
|
|
||||||
"CACEC89AD3A20309748FEC03B0B0C50C",
|
|
||||||
"E7C2D644F989BBA3ADB563A682E591C6",
|
|
||||||
"6359776E10B514A773610D94579BFA3B",
|
|
||||||
"B30FC91ED327EE2E1C7C8B2214D8751A",
|
"B30FC91ED327EE2E1C7C8B2214D8751A",
|
||||||
"3AF4B68A4BB3BD09D371B766E6A1B721",
|
"3119848AE10A9E0858685099EB6C28CC",
|
||||||
"273EC9E9CA27DFDD85478972A1A0ED6F",
|
|
||||||
"A7DDDEAE3438B27260BDC8B1A555CE6F",
|
"A7DDDEAE3438B27260BDC8B1A555CE6F",
|
||||||
"3B27B2B9E70249C339D66F27B7E133F0",
|
"3B27B2B9E70249C339D66F27B7E133F0",
|
||||||
"AED3C29E6DA2F0AA84C08F0F726D59C2",
|
"C031053EDBD2C047C072C53F80D82577",
|
||||||
"6CB820BAC6C0CD8D1F90C342F0EA1018",
|
"8E3DB8D17AD97471F53959CF2F2439FE",
|
||||||
"38C4871110737702A9B3E6CC452977D1",
|
"89425692E74B610F07E9783B75CA299B",
|
||||||
"AED3C29E6DA2F0AA84C08F0F726D59C2",
|
"98640F3DCA10BB955E8039117A1F819F",
|
||||||
"35BA76ED53A953E03F77EE5379C28BE5",
|
"92E3956A3FAF71B6922B0AA8D9ED070A",
|
||||||
"038B83D1D0D374F58821C7EDC4F3B5AE",
|
"1C963AA3BBBD0396784BD0CA527BCDF8",
|
||||||
"0EED5C32E8002D6EF892D3995A0A9AA5",
|
"C5FD1482A207F2CC65570F8FBC492C9A",
|
||||||
"D5A12069E47F17718EF7E7381444A5FE",
|
"5CF1A3455369BDB3D1153D9FC974CAFA",
|
||||||
"9F64084BD36FE0EBCDE1EDC956656501",
|
"E29627AF30D59CF7FE7B01C63BD9A975",
|
||||||
"7516691B34E89137D3C911BBF7D86ACD"
|
"5B43A702C5CC14509CD8FB6F725326FC",
|
||||||
|
"451389BCDC4E8B258DD3F21CDB827589",
|
||||||
|
"57970BD464D679B43A7A0F5585F42677",
|
||||||
|
"21CEF5FF054814ADC61753FFFF417F03",
|
||||||
|
"A47418AED7F226A649E8886FCE2E02B3",
|
||||||
|
"65604889E08858A41E2DDB76D075C3BA",
|
||||||
|
"B7F1BE70638D6747223271745CB0D505",
|
||||||
|
"21CEF5FF054814ADC61753FFFF417F03",
|
||||||
|
"B6AF39DB2F83BEA76726BF0D71CCDDD8",
|
||||||
|
"9B57C79395931A570FB01264D48E9673",
|
||||||
|
"4706B9DB78BBCC66BCB76862EB147AD2",
|
||||||
|
"85B78F013645D1EC53D5F3974528654A"
|
||||||
]
|
]
|
||||||
|
|
||||||
if ($.isNode()) {
|
if ($.isNode()) {
|
||||||
|
125
jd_fcwb.py
125
jd_fcwb.py
@ -1,18 +1,20 @@
|
|||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
'''
|
'''
|
||||||
定时自定义
|
cron: 1 1 1 1 *
|
||||||
35 15 27 5 * jd_fcwb.py
|
|
||||||
new Env('发财挖宝');
|
new Env('发财挖宝');
|
||||||
活动入口: 京东极速版>我的>发财挖宝
|
活动入口: 京东极速版 > 我的 > 发财挖宝
|
||||||
脚本功能为: 挖宝,提现,没有助力功能!
|
最高可得总和为10元的微信零钱和红包
|
||||||
当血量剩余 1 时停止挖宝,领取奖励并提现
|
脚本功能为: 挖宝,提现,没有助力功能,当血量剩余 1 时停止挖宝,领取奖励并提现
|
||||||
|
|
||||||
|
目前需要完成逛一逛任务并且下单任务才能通关,不做的话大概可得1.5~2块的微信零钱
|
||||||
'''
|
'''
|
||||||
import os,json,random,time,re,string,functools,asyncio
|
import os,json,random,time,re,string,functools,asyncio
|
||||||
import sys
|
import sys
|
||||||
sys.path.append('../../tmp')
|
sys.path.append('../../tmp')
|
||||||
|
print('\n运行本脚本之前请手动进入游戏点击一个方块\n')
|
||||||
print('\n挖的如果都是0.01红包就是黑了,别挣扎了!\n')
|
print('\n挖的如果都是0.01红包就是黑了,别挣扎了!\n')
|
||||||
print('\n当血量剩余 1 时停止挖宝,领取奖励并提现,请先跑助力\n')
|
print('\n默认自动领取奖励,关闭请在代码383行加上#号注释即可\n')
|
||||||
try:
|
try:
|
||||||
import requests
|
import requests
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
@ -127,7 +129,7 @@ def taskGetUrl(functionId, body, cookie):
|
|||||||
|
|
||||||
# 剩余血量
|
# 剩余血量
|
||||||
def xueliang(cookie):
|
def xueliang(cookie):
|
||||||
body={"linkId":linkId}
|
body={"linkId":linkId,"round":1}
|
||||||
res=taskGetUrl("happyDigHome", body, cookie)
|
res=taskGetUrl("happyDigHome", body, cookie)
|
||||||
if not res:
|
if not res:
|
||||||
return
|
return
|
||||||
@ -155,16 +157,17 @@ def jinge(cookie,i):
|
|||||||
|
|
||||||
# 页面数据
|
# 页面数据
|
||||||
def happyDigHome(cookie):
|
def happyDigHome(cookie):
|
||||||
body={"linkId":linkId}
|
body={"linkId":linkId,"round":1}
|
||||||
res=taskGetUrl("happyDigHome", body, cookie)
|
res=taskGetUrl("happyDigHome", body, cookie)
|
||||||
|
exit_flag = "false"
|
||||||
if not res:
|
if not res:
|
||||||
return
|
return
|
||||||
if res['code']==0:
|
if res['code']==0:
|
||||||
if res['success']:
|
if res['success']:
|
||||||
curRound=res['data']['curRound'] # 未知
|
curRound=res['data']['curRound'] # 未知
|
||||||
incep_blood=res['data']['blood'] # 剩余血量
|
incep_blood=res['data']['blood'] # 剩余血量
|
||||||
roundList=res['data']['roundList'] # 3个总池子
|
roundList=res['data']['roundList'] # 3个总池子
|
||||||
for e,roundList_n in enumerate(roundList): # 迭代每个池子
|
for e,roundList_n in enumerate(roundList): # 迭代每个池子
|
||||||
roundid=roundList_n['round'] # 池序号
|
roundid=roundList_n['round'] # 池序号
|
||||||
state=roundList_n['state']
|
state=roundList_n['state']
|
||||||
rows=roundList_n['rows'] # 池规模,rows*rows
|
rows=roundList_n['rows'] # 池规模,rows*rows
|
||||||
@ -174,9 +177,14 @@ def happyDigHome(cookie):
|
|||||||
chunks=roundList_n['chunks'] # 当前池详情list
|
chunks=roundList_n['chunks'] # 当前池详情list
|
||||||
|
|
||||||
a=jinge(cookie,roundid)
|
a=jinge(cookie,roundid)
|
||||||
print(f'当前池序号为 {roundid} \n当前池规模为 {rows}*{rows}')
|
if roundid==1:
|
||||||
print(f'剩余血量 {a[0]}')
|
print(f'\n开始 "入门" 难度关卡({rows}*{rows})')
|
||||||
print(f'当前池已得京东红包 {a[2]}\n当前池已得微信红包 {a[1]}\n')
|
elif roundid==2:
|
||||||
|
print(f'\n开始 "挑战" 难度关卡({rows}*{rows})')
|
||||||
|
elif roundid==3:
|
||||||
|
print(f'\n开始 "终极" 难度关卡({rows}*{rows})')
|
||||||
|
print(f'当前剩余血量 {a[0]}🩸')
|
||||||
|
## print(f'当前池已得京东红包 {a[2]}\n当前池已得微信红包 {a[1]}\n')
|
||||||
_blood=xueliang(cookie)
|
_blood=xueliang(cookie)
|
||||||
if _blood>1 or incep_blood>=21:
|
if _blood>1 or incep_blood>=21:
|
||||||
happyDigDo(cookie,roundid,0,0)
|
happyDigDo(cookie,roundid,0,0)
|
||||||
@ -187,35 +195,43 @@ def happyDigHome(cookie):
|
|||||||
for n in range(roundid_n):
|
for n in range(roundid_n):
|
||||||
for i in range(roundid_n):
|
for i in range(roundid_n):
|
||||||
_blood=xueliang(cookie)
|
_blood=xueliang(cookie)
|
||||||
if _blood>1 or incep_blood>=21:
|
if _blood>1 or incep_blood>=21:
|
||||||
print(f'当前血量为 {_blood} 健康,继续挖宝')
|
## print(f'当前血量为 {_blood}')
|
||||||
print(f'本次挖取坐标为 ({n},{i})')
|
a=n+1
|
||||||
|
b=i+1
|
||||||
|
print(f'挖取坐标({a},{b})')
|
||||||
happyDigDo(cookie,roundid,n,i)
|
happyDigDo(cookie,roundid,n,i)
|
||||||
else:
|
else:
|
||||||
a=jinge(cookie,roundid)
|
a=jinge(cookie,roundid)
|
||||||
print(f'当前血量为 {_blood} 不健康,结束该池挖宝')
|
print(f'没血了,不挖了')
|
||||||
print(f'当前池已得京东红包 {a[2]}\n当前池已得微信红包 {a[1]}\n')
|
exit_flag = "true"
|
||||||
|
## print(f'当前池已得京东红包 {a[2]}\n当前池已得微信红包 {a[1]}\n')
|
||||||
break
|
break
|
||||||
|
|
||||||
|
if exit_flag == "true":
|
||||||
|
break
|
||||||
|
if exit_flag == "true":
|
||||||
|
break
|
||||||
else:
|
else:
|
||||||
print(f'获取数据失败\n{res}\n')
|
print(f'获取数据失败\n{res}\n')
|
||||||
else:
|
else:
|
||||||
print(f'获取数据失败\n{res}\n')
|
print(f'获取数据失败\n{res}\n')
|
||||||
|
|
||||||
|
|
||||||
# # 玩一玩
|
# 玩一玩
|
||||||
# def apDoTask(cookie):
|
def apDoTask(cookie):
|
||||||
# print('开始 玩一玩')
|
print('开始做玩一玩任务')
|
||||||
# body={"linkId":linkId,"taskType":"BROWSE_CHANNEL","taskId":454,"channel":4,"itemId":"https%3A%2F%2Fsignfree.jd.com%2F%3FactivityId%3DPiuLvM8vamONsWzC0wqBGQ","checkVersion":False}
|
body={"linkId":linkId,"taskType":"BROWSE_CHANNEL","taskId":454,"channel":4,"itemId":"https%3A%2F%2Fsignfree.jd.com%2F%3FactivityId%3DPiuLvM8vamONsWzC0wqBGQ","checkVersion":False}
|
||||||
# res=taskGetUrl('apDoTask', body, cookie)
|
res=taskGetUrl('apDoTask', body, cookie)
|
||||||
# if not res:
|
if not res:
|
||||||
# return
|
return
|
||||||
# try:
|
try:
|
||||||
# if res['success']:
|
if res['success']:
|
||||||
# print('任务完成,获得血量 1\n')
|
print('玩好了')
|
||||||
# else:
|
else:
|
||||||
# print(f"{res['errMsg']}\n")
|
print(f"{res['errMsg']}")
|
||||||
# except:
|
except:
|
||||||
# print(f"错误\n{res}\n")
|
print(f"错误\n{res}")
|
||||||
|
|
||||||
|
|
||||||
# 挖宝
|
# 挖宝
|
||||||
@ -228,19 +244,19 @@ def happyDigDo(cookie,roundid,rowIdx,colIdx):
|
|||||||
if res['success']:
|
if res['success']:
|
||||||
typeid=res['data']['chunk']['type']
|
typeid=res['data']['chunk']['type']
|
||||||
if typeid==2:
|
if typeid==2:
|
||||||
print(f"挖到京东红包 {res['data']['chunk']['value']}\n")
|
print(f"获得极速版红包 {res['data']['chunk']['value']} 🧧\n")
|
||||||
elif typeid==3:
|
elif typeid==3:
|
||||||
print(f"挖到微信红包 {res['data']['chunk']['value']}\n")
|
print(f"🎉 获得微信零钱 {res['data']['chunk']['value']} 💰\n")
|
||||||
elif typeid==4:
|
elif typeid==4:
|
||||||
print(f"挖到炸弹\n")
|
print(f"💥Boom💥 挖到了炸弹 💣\n")
|
||||||
elif typeid==1:
|
elif typeid==1:
|
||||||
print(f"挖到优惠券\n")
|
print(f"获得优惠券 🎟️\n")
|
||||||
else:
|
else:
|
||||||
print(f'挖到外星物品\n')
|
print(f'不知道挖到了什么 🎁\n')
|
||||||
else:
|
else:
|
||||||
print(f'挖取失败\n{res}\n')
|
print(f'{res}\n挖宝失败\n')
|
||||||
else:
|
else:
|
||||||
print(f'挖取失败\n{res}\n')
|
print(f'{res}\n挖宝失败\n')
|
||||||
|
|
||||||
# # 助力码
|
# # 助力码
|
||||||
# def inviteCode(cookie):
|
# def inviteCode(cookie):
|
||||||
@ -273,10 +289,9 @@ def happyDigDo(cookie,roundid,rowIdx,colIdx):
|
|||||||
|
|
||||||
# 领取奖励
|
# 领取奖励
|
||||||
def happyDigExchange(cookie):
|
def happyDigExchange(cookie):
|
||||||
for n in range(0,4):
|
for n in range(1,4):
|
||||||
xueliang(cookie)
|
xueliang(cookie)
|
||||||
|
print(f"\n开始领取第{n}场的奖励")
|
||||||
print('开始领取奖励')
|
|
||||||
body={"round":n,"linkId":linkId}
|
body={"round":n,"linkId":linkId}
|
||||||
res=taskGetUrl("happyDigExchange", body, cookie)
|
res=taskGetUrl("happyDigExchange", body, cookie)
|
||||||
if not res:
|
if not res:
|
||||||
@ -284,17 +299,18 @@ def happyDigExchange(cookie):
|
|||||||
if res['code']==0:
|
if res['code']==0:
|
||||||
if res['success']:
|
if res['success']:
|
||||||
try:
|
try:
|
||||||
print(f"领取到微信红包 {res['data']['wxValue']}")
|
print(f"已领取极速版红包 {res['data']['redValue']} 🧧")
|
||||||
except:
|
|
||||||
pass
|
|
||||||
try:
|
|
||||||
print(f"领取到京东红包 {res['data']['redValue']}\n")
|
|
||||||
except:
|
except:
|
||||||
print('')
|
print('')
|
||||||
|
if res['data']['wxValue'] != "0":
|
||||||
|
try:
|
||||||
|
print(f"可提现微信零钱 {res['data']['wxValue']} 💰")
|
||||||
|
except:
|
||||||
|
pass
|
||||||
else:
|
else:
|
||||||
print(res['errMsg']+'\n')
|
print(res['errMsg'])
|
||||||
else:
|
else:
|
||||||
print(res['errMsg']+'\n')
|
print(res['errMsg'])
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -316,14 +332,18 @@ def spring_reward_list(cookie):
|
|||||||
poolBaseId=_items['poolBaseId']
|
poolBaseId=_items['poolBaseId']
|
||||||
prizeGroupId=_items['prizeGroupId']
|
prizeGroupId=_items['prizeGroupId']
|
||||||
prizeBaseId=_items['prizeBaseId']
|
prizeBaseId=_items['prizeBaseId']
|
||||||
if '红包' not in prizeDesc:
|
if '红包' in f"{prizeDesc}":
|
||||||
print('尝试微信提现')
|
continue
|
||||||
|
if '券' in f"{prizeDesc}":
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
print('\n去提现微信零钱 💰')
|
||||||
time.sleep(3.2)
|
time.sleep(3.2)
|
||||||
wecat(cookie,amountid,poolBaseId,prizeGroupId,prizeBaseId)
|
wecat(cookie,amountid,poolBaseId,prizeGroupId,prizeBaseId)
|
||||||
else:
|
else:
|
||||||
print(f'获取数据失败\n{res}\n')
|
print(f'获取数据失败\n{res}\n')
|
||||||
else:
|
else:
|
||||||
print(f'获取数据失败\n{res}\n')
|
print(f'获取数据失败\n{res}\n')
|
||||||
|
|
||||||
# 微信提现
|
# 微信提现
|
||||||
def wecat(cookie,amountid,poolBaseId,prizeGroupId,prizeBaseId):
|
def wecat(cookie,amountid,poolBaseId,prizeGroupId,prizeBaseId):
|
||||||
@ -379,6 +399,7 @@ def main():
|
|||||||
|
|
||||||
for e,cookie in enumerate(cookie_list,start=1):
|
for e,cookie in enumerate(cookie_list,start=1):
|
||||||
print(f'******开始【账号 {e}】 {get_pin(cookie)} *********\n')
|
print(f'******开始【账号 {e}】 {get_pin(cookie)} *********\n')
|
||||||
|
apDoTask(cookie)
|
||||||
happyDigHome(cookie)
|
happyDigHome(cookie)
|
||||||
spring_reward_list(cookie)
|
spring_reward_list(cookie)
|
||||||
|
|
||||||
|
562
jd_lzdz1_customized612.js
Normal file
562
jd_lzdz1_customized612.js
Normal file
File diff suppressed because one or more lines are too long
241
jd_superBrandSign.js
Normal file
241
jd_superBrandSign.js
Normal file
File diff suppressed because one or more lines are too long
86
jd_wish.js
86
jd_wish.js
File diff suppressed because one or more lines are too long
640
wskey.py
Normal file
640
wskey.py
Normal file
@ -0,0 +1,640 @@
|
|||||||
|
# -*- coding: utf-8 -*
|
||||||
|
'''
|
||||||
|
new Env('wskey转换');
|
||||||
|
'''
|
||||||
|
import socket # 用于端口检测
|
||||||
|
import base64 # 用于编解码
|
||||||
|
import json # 用于Json解析
|
||||||
|
import os # 用于导入系统变量
|
||||||
|
import sys # 实现 sys.exit
|
||||||
|
import logging # 用于日志输出
|
||||||
|
import time # 时间
|
||||||
|
import re # 正则过滤
|
||||||
|
import hmac
|
||||||
|
import struct
|
||||||
|
|
||||||
|
WSKEY_MODE = 0
|
||||||
|
# 0 = Default / 1 = Debug!
|
||||||
|
|
||||||
|
if "WSKEY_DEBUG" in os.environ or WSKEY_MODE: # 判断调试模式变量
|
||||||
|
logging.basicConfig(level=logging.DEBUG, format='%(message)s') # 设置日志为 Debug等级输出
|
||||||
|
logger = logging.getLogger(__name__) # 主模块
|
||||||
|
logger.debug("\nDEBUG模式开启!\n") # 消息输出
|
||||||
|
else: # 判断分支
|
||||||
|
logging.basicConfig(level=logging.INFO, format='%(message)s') # Info级日志
|
||||||
|
logger = logging.getLogger(__name__) # 主模块
|
||||||
|
|
||||||
|
try: # 异常捕捉
|
||||||
|
import requests # 导入HTTP模块
|
||||||
|
except Exception as e: # 异常捕捉
|
||||||
|
logger.info(str(e) + "\n缺少requests模块, 请执行命令:pip3 install requests\n") # 日志输出
|
||||||
|
sys.exit(1) # 退出脚本
|
||||||
|
os.environ['no_proxy'] = '*' # 禁用代理
|
||||||
|
requests.packages.urllib3.disable_warnings() # 抑制错误
|
||||||
|
try: # 异常捕捉
|
||||||
|
from notify import send # 导入青龙消息通知模块
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
logger.info("无推送文件") # 标准日志输出
|
||||||
|
|
||||||
|
ver = 20524 # 版本号
|
||||||
|
|
||||||
|
|
||||||
|
# def ql_2fa():
|
||||||
|
# ''' Demo
|
||||||
|
# if "WSKEY_TOKEN" in os.environ:
|
||||||
|
# url = 'http://127.0.0.1:{0}/api/user'.format(port) # 设置 URL地址
|
||||||
|
# try: # 异常捕捉
|
||||||
|
# res = s.get(url) # HTTP请求 [GET] 使用 session
|
||||||
|
# except Exception as err: # 异常捕捉
|
||||||
|
# logger.debug(str(err)) # 调试日志输出
|
||||||
|
# else: # 判断分支
|
||||||
|
# if res.status_code == 200 and res.json()["code"] == 200:
|
||||||
|
# twoFactorActivated = str(res.json()["data"]["twoFactorActivated"])
|
||||||
|
# if twoFactorActivated == 'true':
|
||||||
|
# logger.info("青龙 2FA 已开启!")
|
||||||
|
# url = 'http://127.0.0.1:{0}/api/envs?searchValue=WSKEY_Client'.format(port) # 设置 URL地址
|
||||||
|
# res = s.get(url)
|
||||||
|
# if res.status_code == 200 and res.json()["code"] == 200:
|
||||||
|
# data = res.json()["data"]
|
||||||
|
# if len(data) == 0:
|
||||||
|
# url = 'http://127.0.0.1:{0}/api/apps'
|
||||||
|
# data = json.dumps({
|
||||||
|
# "name": "wskey",
|
||||||
|
# "scopes": ["crons", "envs", "configs", "scripts", "logs", "dependencies", "system"]
|
||||||
|
# })
|
||||||
|
# res = s.post(url, data=data)
|
||||||
|
# if res.status_code == 200 and res.json()["code"] == 200:
|
||||||
|
# logger.info("OpenApi创建成功")
|
||||||
|
# client_id = res.json()["data"]["client_id"]
|
||||||
|
# client_secret = res.json()["data"]["client_secret"]
|
||||||
|
# wskey_value = 'client_id={0}&client_secret={1}'.format(client_id, client_secret)
|
||||||
|
# data = [{"value": wskey_value, "name": "WSKEY_Client", "remarks": "WSKEY_OpenApi请勿删除"}]
|
||||||
|
# data = json.dumps(data) # Json格式化数据
|
||||||
|
# url = 'http://127.0.0.1:{0}/api/envs'.format(port) # 设置 URL地址
|
||||||
|
# s.post(url=url, data=data) # HTTP[POST]请求 使用session
|
||||||
|
# logger.info("\nWSKEY_Client变量添加完成\n--------------------\n") # 标准日志输出
|
||||||
|
# '''
|
||||||
|
|
||||||
|
def ttotp(key):
|
||||||
|
key = base64.b32decode(key.upper() + '=' * ((8 - len(key)) % 8))
|
||||||
|
counter = struct.pack('>Q', int(time.time() / 30))
|
||||||
|
mac = hmac.new(key, counter, 'sha1').digest()
|
||||||
|
offset = mac[-1] & 0x0f
|
||||||
|
binary = struct.unpack('>L', mac[offset:offset + 4])[0] & 0x7fffffff
|
||||||
|
return str(binary)[-6:].zfill(6)
|
||||||
|
|
||||||
|
|
||||||
|
def ql_send(text):
|
||||||
|
if "WSKEY_SEND" in os.environ and os.environ["WSKEY_SEND"] == 'disable':
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
try: # 异常捕捉
|
||||||
|
send('WSKEY转换', text) # 消息发送
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # Debug日志输出
|
||||||
|
logger.info("通知发送失败") # 标准日志输出
|
||||||
|
|
||||||
|
|
||||||
|
# 登录青龙 返回值 token
|
||||||
|
def get_qltoken(username, password, twoFactorSecret): # 方法 用于获取青龙 Token
|
||||||
|
logger.info("Token失效, 新登陆\n") # 日志输出
|
||||||
|
if twoFactorSecret:
|
||||||
|
try:
|
||||||
|
twoCode = ttotp(twoFactorSecret)
|
||||||
|
except Exception as err:
|
||||||
|
logger.debug(str(err)) # Debug日志输出
|
||||||
|
logger.info("TOTP异常")
|
||||||
|
sys.exit(1)
|
||||||
|
url = ql_url + "api/user/login" # 设置青龙地址 使用 format格式化自定义端口
|
||||||
|
payload = json.dumps({
|
||||||
|
'username': username,
|
||||||
|
'password': password
|
||||||
|
}) # HTTP请求载荷
|
||||||
|
headers = {
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
} # HTTP请求头 设置为 Json格式
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = requests.post(url=url, headers=headers, data=payload) # 使用 requests模块进行 HTTP POST请求
|
||||||
|
if res.status_code == 200 and res.json()["code"] == 420:
|
||||||
|
url = ql_url + 'api/user/two-factor/login'
|
||||||
|
data = json.dumps({
|
||||||
|
"username": username,
|
||||||
|
"password": password,
|
||||||
|
"code": twoCode
|
||||||
|
})
|
||||||
|
res = requests.put(url=url, headers=headers, data=data)
|
||||||
|
if res.status_code == 200 and res.json()["code"] == 200:
|
||||||
|
token = res.json()["data"]['token'] # 从 res.text 返回值中 取出 Token值
|
||||||
|
return token
|
||||||
|
else:
|
||||||
|
logger.info("两步校验失败\n") # 日志输出
|
||||||
|
sys.exit(1)
|
||||||
|
elif res.status_code == 200 and res.json()["code"] == 200:
|
||||||
|
token = res.json()["data"]['token'] # 从 res.text 返回值中 取出 Token值
|
||||||
|
return token
|
||||||
|
except Exception as err:
|
||||||
|
logger.debug(str(err)) # Debug日志输出
|
||||||
|
sys.exit(1)
|
||||||
|
else:
|
||||||
|
url = ql_url + 'api/user/login'
|
||||||
|
payload = {
|
||||||
|
'username': username,
|
||||||
|
'password': password
|
||||||
|
} # HTTP请求载荷
|
||||||
|
payload = json.dumps(payload) # json格式化载荷
|
||||||
|
headers = {
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
} # HTTP请求头 设置为 Json格式
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = requests.post(url=url, headers=headers, data=payload) # 使用 requests模块进行 HTTP POST请求
|
||||||
|
if res.status_code == 200 and res.json()["code"] == 200:
|
||||||
|
token = res.json()["data"]['token'] # 从 res.text 返回值中 取出 Token值
|
||||||
|
return token
|
||||||
|
else:
|
||||||
|
ql_send("青龙登录失败!")
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
except Exception as err:
|
||||||
|
logger.debug(str(err)) # Debug日志输出
|
||||||
|
logger.info("使用旧版青龙登录接口")
|
||||||
|
url = ql_url + 'api/login' # 设置青龙地址 使用 format格式化自定义端口
|
||||||
|
payload = {
|
||||||
|
'username': username,
|
||||||
|
'password': password
|
||||||
|
} # HTTP请求载荷
|
||||||
|
payload = json.dumps(payload) # json格式化载荷
|
||||||
|
headers = {
|
||||||
|
'Accept': 'application/json',
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
} # HTTP请求头 设置为 Json格式
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = requests.post(url=url, headers=headers, data=payload) # 使用 requests模块进行 HTTP POST请求
|
||||||
|
token = json.loads(res.text)["data"]['token'] # 从 res.text 返回值中 取出 Token值
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # Debug日志输出
|
||||||
|
logger.info("青龙登录失败, 请检查面板状态!") # 标准日志输出
|
||||||
|
ql_send('青龙登陆失败, 请检查面板状态.')
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 无异常执行分支
|
||||||
|
return token # 返回 token值
|
||||||
|
# else: # 无异常执行分支
|
||||||
|
# return token # 返回 token值
|
||||||
|
|
||||||
|
|
||||||
|
# 返回值 Token
|
||||||
|
def ql_login(): # 方法 青龙登录(获取Token 功能同上)
|
||||||
|
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模块读取
|
||||||
|
username = auth["username"] # 提取 username
|
||||||
|
password = auth["password"] # 提取 password
|
||||||
|
token = auth["token"] # 提取 authkey
|
||||||
|
try:
|
||||||
|
twoFactorSecret = auth["twoFactorSecret"]
|
||||||
|
except Exception as err:
|
||||||
|
logger.debug(str(err)) # Debug日志输出
|
||||||
|
twoFactorSecret = ''
|
||||||
|
if token == '': # 判断 Token是否为空
|
||||||
|
return get_qltoken(username, password, twoFactorSecret) # 调用方法 get_qltoken 传递 username & password
|
||||||
|
else: # 判断分支
|
||||||
|
url = ql_url + 'api/user' # 设置URL请求地址 使用 Format格式化端口
|
||||||
|
headers = {
|
||||||
|
'Authorization': 'Bearer {0}'.format(token),
|
||||||
|
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/94.0.4606.71 Safari/537.36 Edg/94.0.992.38'
|
||||||
|
} # 设置用于 HTTP头
|
||||||
|
res = requests.get(url=url, headers=headers) # 调用 request模块发送 get请求
|
||||||
|
if res.status_code == 200: # 判断 HTTP返回状态码
|
||||||
|
return token # 有效 返回 token
|
||||||
|
else: # 判断分支
|
||||||
|
return get_qltoken(username, password, twoFactorSecret) # 调用方法 get_qltoken 传递 username & password
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("没有发现auth文件, 你这是青龙吗???") # 输出标准日志
|
||||||
|
sys.exit(0) # 脚本退出
|
||||||
|
|
||||||
|
|
||||||
|
# 返回值 list[wskey]
|
||||||
|
def get_wskey(): # 方法 获取 wskey值 [系统变量传递]
|
||||||
|
if "JD_WSCK" in os.environ: # 判断 JD_WSCK是否存在于环境变量
|
||||||
|
wskey_list = os.environ['JD_WSCK'].split('&') # 读取系统变量 以 & 分割变量
|
||||||
|
if len(wskey_list) > 0: # 判断 WSKEY 数量 大于 0 个
|
||||||
|
return wskey_list # 返回 WSKEY [LIST]
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("JD_WSCK变量未启用") # 标准日志输出
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("未添加JD_WSCK变量") # 标准日志输出
|
||||||
|
sys.exit(0) # 脚本退出
|
||||||
|
|
||||||
|
|
||||||
|
# 返回值 list[jd_cookie]
|
||||||
|
def get_ck(): # 方法 获取 JD_COOKIE值 [系统变量传递] <! 此方法未使用 !>
|
||||||
|
if "JD_COOKIE" in os.environ: # 判断 JD_COOKIE是否存在于环境变量
|
||||||
|
ck_list = os.environ['JD_COOKIE'].split('&') # 读取系统变量 以 & 分割变量
|
||||||
|
if len(ck_list) > 0: # 判断 WSKEY 数量 大于 0 个
|
||||||
|
return ck_list # 返回 JD_COOKIE [LIST]
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("JD_COOKIE变量未启用") # 标准日志输出
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("未添加JD_COOKIE变量") # 标准日志输出
|
||||||
|
sys.exit(0) # 脚本退出
|
||||||
|
|
||||||
|
|
||||||
|
# 返回值 bool
|
||||||
|
def check_ck(ck): # 方法 检查 Cookie有效性 使用变量传递 单次调用
|
||||||
|
searchObj = re.search(r'pt_pin=([^;\s]+)', ck, re.M | re.I) # 正则检索 pt_pin
|
||||||
|
if searchObj: # 真值判断
|
||||||
|
pin = searchObj.group(1) # 取值
|
||||||
|
else: # 判断分支
|
||||||
|
pin = ck.split(";")[1] # 取值 使用 ; 分割
|
||||||
|
if "WSKEY_UPDATE_HOUR" in os.environ: # 判断 WSKEY_UPDATE_HOUR是否存在于环境变量
|
||||||
|
updateHour = 23 # 更新间隔23小时
|
||||||
|
if os.environ["WSKEY_UPDATE_HOUR"].isdigit(): # 检查是否为 DEC值
|
||||||
|
updateHour = int(os.environ["WSKEY_UPDATE_HOUR"]) # 使用 int化数字
|
||||||
|
nowTime = time.time() # 获取时间戳 赋值
|
||||||
|
updatedAt = 0.0 # 赋值
|
||||||
|
searchObj = re.search(r'__time=([^;\s]+)', ck, re.M | re.I) # 正则检索 [__time=]
|
||||||
|
if searchObj: # 真值判断
|
||||||
|
updatedAt = float(searchObj.group(1)) # 取值 [float]类型
|
||||||
|
if nowTime - updatedAt >= (updateHour * 60 * 60) - (10 * 60): # 判断时间操作
|
||||||
|
logger.info(str(pin) + ";即将到期或已过期\n") # 标准日志输出
|
||||||
|
return False # 返回 Bool类型 False
|
||||||
|
else: # 判断分支
|
||||||
|
remainingTime = (updateHour * 60 * 60) - (nowTime - updatedAt) # 时间运算操作
|
||||||
|
hour = int(remainingTime / 60 / 60) # 时间运算操作 [int]
|
||||||
|
minute = int((remainingTime % 3600) / 60) # 时间运算操作 [int]
|
||||||
|
logger.info(str(pin) + ";未到期,{0}时{1}分后更新\n".format(hour, minute)) # 标准日志输出
|
||||||
|
return True # 返回 Bool类型 True
|
||||||
|
elif "WSKEY_DISCHECK" in os.environ: # 判断分支 WSKEY_DISCHECK 是否存在于系统变量
|
||||||
|
logger.info("不检查账号有效性\n--------------------\n") # 标准日志输出
|
||||||
|
return False # 返回 Bool类型 False
|
||||||
|
else: # 判断分支
|
||||||
|
url = 'https://me-api.jd.com/user_new/info/GetJDUserInfoUnion' # 设置JD_API接口地址
|
||||||
|
headers = {
|
||||||
|
'Cookie': ck,
|
||||||
|
'Referer': 'https://home.m.jd.com/myJd/home.action',
|
||||||
|
'user-agent': ua
|
||||||
|
} # 设置 HTTP头
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = requests.get(url=url, headers=headers, verify=False, timeout=10) # 进行 HTTP请求[GET] 超时 10秒
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
logger.info("JD接口错误 请重试或者更换IP") # 标准日志输出
|
||||||
|
return False # 返回 Bool类型 False
|
||||||
|
else: # 判断分支
|
||||||
|
if res.status_code == 200: # 判断 JD_API 接口是否为 200 [HTTP_OK]
|
||||||
|
code = int(json.loads(res.text)['retcode']) # 使用 Json模块对返回数据取值 int([retcode])
|
||||||
|
if code == 0: # 判断 code值
|
||||||
|
logger.info(str(pin) + ";状态正常\n") # 标准日志输出
|
||||||
|
return True # 返回 Bool类型 True
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info(str(pin) + ";状态失效\n")
|
||||||
|
return False # 返回 Bool类型 False
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("JD接口错误码: " + str(res.status_code)) # 标注日志输出
|
||||||
|
return False # 返回 Bool类型 False
|
||||||
|
|
||||||
|
|
||||||
|
# 返回值 bool jd_ck
|
||||||
|
def getToken(wskey): # 方法 获取 Wskey转换使用的 Token 由 JD_API 返回 这里传递 wskey
|
||||||
|
try: # 异常捕捉
|
||||||
|
url = str(base64.b64decode(url_t).decode()) + 'api/genToken' # 设置云端服务器地址 路由为 genToken
|
||||||
|
header = {"User-Agent": ua} # 设置 HTTP头
|
||||||
|
params = requests.get(url=url, headers=header, verify=False, timeout=20).json() # 设置 HTTP请求参数 超时 20秒 Json解析
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.info("Params参数获取失败") # 标准日志输出
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
return False, wskey # 返回 -> False[Bool], Wskey
|
||||||
|
headers = {
|
||||||
|
'cookie': wskey,
|
||||||
|
'content-type': 'application/x-www-form-urlencoded; charset=UTF-8',
|
||||||
|
'charset': 'UTF-8',
|
||||||
|
'accept-encoding': 'br,gzip,deflate',
|
||||||
|
'user-agent': ua
|
||||||
|
} # 设置 HTTP头
|
||||||
|
url = 'https://api.m.jd.com/client.action' # 设置 URL地址
|
||||||
|
data = 'body=%7B%22to%22%3A%22https%253a%252f%252fplogin.m.jd.com%252fjd-mlogin%252fstatic%252fhtml%252fappjmp_blank.html%22%7D&' # 设置 POST 载荷
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = requests.post(url=url, params=params, headers=headers, data=data, verify=False,
|
||||||
|
timeout=10) # HTTP请求 [POST] 超时 10秒
|
||||||
|
res_json = json.loads(res.text) # Json模块 取值
|
||||||
|
tokenKey = res_json['tokenKey'] # 取出TokenKey
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.info("JD_WSKEY接口抛出错误 尝试重试 更换IP") # 标准日志输出
|
||||||
|
logger.info(str(err)) # 标注日志输出
|
||||||
|
return False, wskey # 返回 -> False[Bool], Wskey
|
||||||
|
else: # 判断分支
|
||||||
|
return appjmp(wskey, tokenKey) # 传递 wskey, Tokenkey 执行方法 [appjmp]
|
||||||
|
|
||||||
|
|
||||||
|
# 返回值 bool jd_ck
|
||||||
|
def appjmp(wskey, tokenKey): # 方法 传递 wskey & tokenKey
|
||||||
|
wskey = "pt_" + str(wskey.split(";")[0]) # 变量组合 使用 ; 分割变量 拼接 pt_
|
||||||
|
if tokenKey == 'xxx': # 判断 tokenKey返回值
|
||||||
|
logger.info(str(wskey) + ";疑似IP风控等问题 默认为失效\n--------------------\n") # 标准日志输出
|
||||||
|
return False, wskey # 返回 -> False[Bool], Wskey
|
||||||
|
headers = {
|
||||||
|
'User-Agent': ua,
|
||||||
|
'accept': 'accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
|
||||||
|
'x-requested-with': 'com.jingdong.app.mall'
|
||||||
|
} # 设置 HTTP头
|
||||||
|
params = {
|
||||||
|
'tokenKey': tokenKey,
|
||||||
|
'to': 'https://plogin.m.jd.com/jd-mlogin/static/html/appjmp_blank.html'
|
||||||
|
} # 设置 HTTP_URL 参数
|
||||||
|
url = 'https://un.m.jd.com/cgi-bin/app/appjmp' # 设置 URL地址
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = requests.get(url=url, headers=headers, params=params, verify=False, allow_redirects=False,
|
||||||
|
timeout=20) # HTTP请求 [GET] 阻止跳转 超时 20秒
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.info("JD_appjmp 接口错误 请重试或者更换IP\n") # 标准日志输出
|
||||||
|
logger.info(str(err)) # 标准日志输出
|
||||||
|
return False, wskey # 返回 -> False[Bool], Wskey
|
||||||
|
else: # 判断分支
|
||||||
|
try: # 异常捕捉
|
||||||
|
res_set = res.cookies.get_dict() # 从res cookie取出
|
||||||
|
pt_key = 'pt_key=' + res_set['pt_key'] # 取值 [pt_key]
|
||||||
|
pt_pin = 'pt_pin=' + res_set['pt_pin'] # 取值 [pt_pin]
|
||||||
|
if "WSKEY_UPDATE_HOUR" in os.environ: # 判断是否在系统变量中启用 WSKEY_UPDATE_HOUR
|
||||||
|
jd_ck = str(pt_key) + ';' + str(pt_pin) + ';__time=' + str(time.time()) + ';' # 拼接变量
|
||||||
|
else: # 判断分支
|
||||||
|
jd_ck = str(pt_key) + ';' + str(pt_pin) + ';' # 拼接变量
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.info("JD_appjmp提取Cookie错误 请重试或者更换IP\n") # 标准日志输出
|
||||||
|
logger.info(str(err)) # 标准日志输出
|
||||||
|
return False, wskey # 返回 -> False[Bool], Wskey
|
||||||
|
else: # 判断分支
|
||||||
|
if 'fake' in pt_key: # 判断 pt_key中 是否存在fake
|
||||||
|
logger.info(str(wskey) + ";WsKey状态失效\n") # 标准日志输出
|
||||||
|
return False, wskey # 返回 -> False[Bool], Wskey
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info(str(wskey) + ";WsKey状态正常\n") # 标准日志输出
|
||||||
|
return True, jd_ck # 返回 -> True[Bool], jd_ck
|
||||||
|
|
||||||
|
|
||||||
|
def update(): # 方法 脚本更新模块
|
||||||
|
up_ver = int(cloud_arg['update']) # 云端参数取值 [int]
|
||||||
|
if ver >= up_ver: # 判断版本号大小
|
||||||
|
logger.info("当前脚本版本: " + str(ver)) # 标准日志输出
|
||||||
|
logger.info("--------------------\n") # 标准日志输出
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("当前脚本版本: " + str(ver) + "新版本: " + str(up_ver)) # 标准日志输出
|
||||||
|
logger.info("存在新版本, 请更新脚本后执行") # 标准日志输出
|
||||||
|
logger.info("--------------------\n") # 标准日志输出
|
||||||
|
text = '当前脚本版本: {0}新版本: {1}, 请更新脚本~!'.format(ver, up_ver) # 设置发送内容
|
||||||
|
ql_send(text)
|
||||||
|
# sys.exit(0) # 退出脚本 [未启用]
|
||||||
|
|
||||||
|
|
||||||
|
def ql_check(port): # 方法 检查青龙端口
|
||||||
|
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # Socket模块初始化
|
||||||
|
sock.settimeout(2) # 设置端口超时
|
||||||
|
try: # 异常捕捉
|
||||||
|
sock.connect(('127.0.0.1', port)) # 请求端口
|
||||||
|
except Exception as err: # 捕捉异常
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
sock.close() # 端口关闭
|
||||||
|
return False # 返回 -> False[Bool]
|
||||||
|
else: # 分支判断
|
||||||
|
sock.close() # 关闭端口
|
||||||
|
return True # 返回 -> True[Bool]
|
||||||
|
|
||||||
|
|
||||||
|
def serch_ck(pin): # 方法 搜索 Pin
|
||||||
|
for i in range(len(envlist)): # For循环 变量[envlist]的数量
|
||||||
|
if "name" not in envlist[i] or envlist[i]["name"] != "JD_COOKIE": # 判断 envlist内容
|
||||||
|
continue # 继续循环
|
||||||
|
if pin in envlist[i]['value']: # 判断envlist取值['value']
|
||||||
|
value = envlist[i]['value'] # 取值['value']
|
||||||
|
id = envlist[i][ql_id] # 取值 [ql_id](变量)
|
||||||
|
logger.info(str(pin) + "检索成功\n") # 标准日志输出
|
||||||
|
return True, value, id # 返回 -> True[Bool], value, id
|
||||||
|
else: # 判断分支
|
||||||
|
continue # 继续循环
|
||||||
|
logger.info(str(pin) + "检索失败\n") # 标准日志输出
|
||||||
|
return False, 1 # 返回 -> False[Bool], 1
|
||||||
|
|
||||||
|
|
||||||
|
def get_env(): # 方法 读取变量
|
||||||
|
url = ql_url + 'api/envs'
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = s.get(url) # HTTP请求 [GET] 使用 session
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
logger.info("\n青龙环境接口错误") # 标准日志输出
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 判断分支
|
||||||
|
data = json.loads(res.text)['data'] # 使用Json模块提取值[data]
|
||||||
|
return data # 返回 -> data
|
||||||
|
|
||||||
|
|
||||||
|
def check_id(): # 方法 兼容青龙老版本与新版本 id & _id的问题
|
||||||
|
url = ql_url + 'api/envs'
|
||||||
|
try: # 异常捕捉
|
||||||
|
res = s.get(url).json() # HTTP[GET] 请求 使用 session
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
logger.info("\n青龙环境接口错误") # 标准日志输出
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 判断分支
|
||||||
|
if '_id' in res['data'][0]: # 判断 [_id]
|
||||||
|
logger.info("使用 _id 键值") # 标准日志输出
|
||||||
|
return '_id' # 返回 -> '_id'
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("使用 id 键值") # 标准日志输出
|
||||||
|
return 'id' # 返回 -> 'id'
|
||||||
|
|
||||||
|
|
||||||
|
def ql_update(e_id, n_ck): # 方法 青龙更新变量 传递 id cookie
|
||||||
|
url = ql_url + 'api/envs'
|
||||||
|
data = {
|
||||||
|
"name": "JD_COOKIE",
|
||||||
|
"value": n_ck,
|
||||||
|
ql_id: e_id
|
||||||
|
} # 设置 HTTP POST 载荷
|
||||||
|
data = json.dumps(data) # json模块格式化
|
||||||
|
s.put(url=url, data=data) # HTTP [PUT] 请求 使用 session
|
||||||
|
ql_enable(eid) # 调用方法 ql_enable 传递 eid
|
||||||
|
|
||||||
|
|
||||||
|
def ql_enable(e_id): # 方法 青龙变量启用 传递值 eid
|
||||||
|
url = ql_url + 'api/envs/enable'
|
||||||
|
data = '["{0}"]'.format(e_id) # 格式化 POST 载荷
|
||||||
|
res = json.loads(s.put(url=url, data=data).text) # json模块读取 HTTP[PUT] 的返回值
|
||||||
|
if res['code'] == 200: # 判断返回值为 200
|
||||||
|
logger.info("\n账号启用\n--------------------\n") # 标准日志输出
|
||||||
|
return True # 返回 ->True
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("\n账号启用失败\n--------------------\n") # 标准日志输出
|
||||||
|
return False # 返回 -> Fasle
|
||||||
|
|
||||||
|
|
||||||
|
def ql_disable(e_id): # 方法 青龙变量禁用 传递 eid
|
||||||
|
url = ql_url + 'api/envs/disable'
|
||||||
|
data = '["{0}"]'.format(e_id) # 格式化 POST 载荷
|
||||||
|
res = json.loads(s.put(url=url, data=data).text) # json模块读取 HTTP[PUT] 的返回值
|
||||||
|
if res['code'] == 200: # 判断返回值为 200
|
||||||
|
logger.info("\n账号禁用成功\n--------------------\n") # 标准日志输出
|
||||||
|
return True # 返回 ->True
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("\n账号禁用失败\n--------------------\n") # 标准日志输出
|
||||||
|
return False # 返回 -> Fasle
|
||||||
|
|
||||||
|
|
||||||
|
def ql_insert(i_ck): # 方法 插入新变量
|
||||||
|
data = [{"value": i_ck, "name": "JD_COOKIE"}] # POST数据载荷组合
|
||||||
|
data = json.dumps(data) # Json格式化数据
|
||||||
|
url = ql_url + 'api/envs'
|
||||||
|
s.post(url=url, data=data) # HTTP[POST]请求 使用session
|
||||||
|
logger.info("\n账号添加完成\n--------------------\n") # 标准日志输出
|
||||||
|
|
||||||
|
|
||||||
|
def cloud_info(): # 方法 云端信息
|
||||||
|
url = str(base64.b64decode(url_t).decode()) + 'api/check_api' # 设置 URL地址 路由 [check_api]
|
||||||
|
for i in range(3): # For循环 3次
|
||||||
|
try: # 异常捕捉
|
||||||
|
headers = {"authorization": "Bearer Shizuku"} # 设置 HTTP头
|
||||||
|
res = requests.get(url=url, verify=False, headers=headers, timeout=20).text # HTTP[GET] 请求 超时 20秒
|
||||||
|
except requests.exceptions.ConnectTimeout: # 异常捕捉
|
||||||
|
logger.info("\n获取云端参数超时, 正在重试!" + str(i)) # 标准日志输出
|
||||||
|
time.sleep(1) # 休眠 1秒
|
||||||
|
continue # 循环继续
|
||||||
|
except requests.exceptions.ReadTimeout: # 异常捕捉
|
||||||
|
logger.info("\n获取云端参数超时, 正在重试!" + str(i)) # 标准日志输出
|
||||||
|
time.sleep(1) # 休眠 1秒
|
||||||
|
continue # 循环继续
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.info("\n未知错误云端, 退出脚本!") # 标准日志输出
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 分支判断
|
||||||
|
try: # 异常捕捉
|
||||||
|
c_info = json.loads(res) # json读取参数
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.info("云端参数解析失败") # 标准日志输出
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 分支判断
|
||||||
|
return c_info # 返回 -> c_info
|
||||||
|
|
||||||
|
|
||||||
|
def check_cloud(): # 方法 云端地址检查
|
||||||
|
url_list = ['aHR0cDovL2FwaS5tb21vZS5tbC8=', 'aHR0cHM6Ly9hcGkubW9tb2UubWwv',
|
||||||
|
'aHR0cHM6Ly9hcGkuaWxpeWEuY2Yv'] # URL list Encode
|
||||||
|
for i in url_list: # for循环 url_list
|
||||||
|
url = str(base64.b64decode(i).decode()) # 设置 url地址 [str]
|
||||||
|
try: # 异常捕捉
|
||||||
|
requests.get(url=url, verify=False, timeout=10) # HTTP[GET]请求 超时 10秒
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
continue # 循环继续
|
||||||
|
else: # 分支判断
|
||||||
|
info = ['HTTP', 'HTTPS', 'CloudFlare'] # 输出信息[List]
|
||||||
|
logger.info(str(info[url_list.index(i)]) + " Server Check OK\n--------------------\n") # 标准日志输出
|
||||||
|
return i # 返回 ->i
|
||||||
|
logger.info("\n云端地址全部失效, 请检查网络!") # 标准日志输出
|
||||||
|
ql_send('云端地址失效. 请联系作者或者检查网络.') # 推送消息
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
|
||||||
|
|
||||||
|
def check_port(): # 方法 检查变量传递端口
|
||||||
|
logger.info("\n--------------------\n") # 标准日志输出
|
||||||
|
if "QL_PORT" in os.environ: # 判断 系统变量是否存在[QL_PORT]
|
||||||
|
try: # 异常捕捉
|
||||||
|
port = int(os.environ['QL_PORT']) # 取值 [int]
|
||||||
|
except Exception as err: # 异常捕捉
|
||||||
|
logger.debug(str(err)) # 调试日志输出
|
||||||
|
logger.info("变量格式有问题...\n格式: export QL_PORT=\"端口号\"") # 标准日志输出
|
||||||
|
logger.info("使用默认端口5700") # 标准日志输出
|
||||||
|
return 5700 # 返回端口 5700
|
||||||
|
else: # 判断分支
|
||||||
|
port = 5700 # 默认5700端口
|
||||||
|
if not ql_check(port): # 调用方法 [ql_check] 传递 [port]
|
||||||
|
logger.info(str(port) + "端口检查失败, 如果改过端口, 请在变量中声明端口 \n在config.sh中加入 export QL_PORT=\"端口号\"") # 标准日志输出
|
||||||
|
logger.info("\n如果你很确定端口没错, 还是无法执行, 在GitHub给我发issus\n--------------------\n") # 标准日志输出
|
||||||
|
sys.exit(1) # 脚本退出
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info(str(port) + "端口检查通过") # 标准日志输出
|
||||||
|
return port # 返回->port
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__': # Python主函数执行入口
|
||||||
|
port = check_port() # 调用方法 [check_port] 并赋值 [port]
|
||||||
|
ql_url = 'http://127.0.0.1:{0}/'.format(port)
|
||||||
|
token = ql_login() # 调用方法 [ql_login] 并赋值 [token]
|
||||||
|
s = requests.session() # 设置 request session方法
|
||||||
|
s.headers.update({"authorization": "Bearer " + str(token)}) # 增加 HTTP头认证
|
||||||
|
s.headers.update({"Content-Type": "application/json;charset=UTF-8"}) # 增加 HTTP头 json 类型
|
||||||
|
ql_id = check_id() # 调用方法 [check_id] 并赋值 [ql_id]
|
||||||
|
url_t = check_cloud() # 调用方法 [check_cloud] 并赋值 [url_t]
|
||||||
|
cloud_arg = cloud_info() # 调用方法 [cloud_info] 并赋值 [cloud_arg]
|
||||||
|
update() # 调用方法 [update]
|
||||||
|
ua = cloud_arg['User-Agent'] # 设置全局变量 UA
|
||||||
|
wslist = get_wskey() # 调用方法 [get_wskey] 并赋值 [wslist]
|
||||||
|
envlist = get_env() # 调用方法 [get_env] 并赋值 [envlist]
|
||||||
|
if "WSKEY_SLEEP" in os.environ and str(os.environ["WSKEY_SLEEP"]).isdigit(): # 判断变量[WSKEY_SLEEP]是否为数字类型
|
||||||
|
sleepTime = int(os.environ["WSKEY_SLEEP"]) # 获取变量 [int]
|
||||||
|
else: # 判断分支
|
||||||
|
sleepTime = 10 # 默认休眠时间 10秒
|
||||||
|
for ws in wslist: # wslist变量 for循环 [wslist -> ws]
|
||||||
|
wspin = ws.split(";")[0] # 变量分割 ;
|
||||||
|
if "pin" in wspin: # 判断 pin 是否存在于 [wspin]
|
||||||
|
wspin = "pt_" + wspin + ";" # 封闭变量
|
||||||
|
return_serch = serch_ck(wspin) # 变量 pt_pin 搜索获取 key eid
|
||||||
|
if return_serch[0]: # bool: True 搜索到账号
|
||||||
|
jck = str(return_serch[1]) # 拿到 JD_COOKIE
|
||||||
|
if not check_ck(jck): # bool: False 判定 JD_COOKIE 有效性
|
||||||
|
tryCount = 1 # 重试次数 1次
|
||||||
|
if "WSKEY_TRY_COUNT" in os.environ: # 判断 [WSKEY_TRY_COUNT] 是否存在于系统变量
|
||||||
|
if os.environ["WSKEY_TRY_COUNT"].isdigit(): # 判断 [WSKEY_TRY_COUNT] 是否为数字
|
||||||
|
tryCount = int(os.environ["WSKEY_TRY_COUNT"]) # 设置 [tryCount] int
|
||||||
|
for count in range(tryCount): # for循环 [tryCount]
|
||||||
|
count += 1 # 自增
|
||||||
|
return_ws = getToken(ws) # 使用 WSKEY 请求获取 JD_COOKIE bool jd_ck
|
||||||
|
if return_ws[0]: # 判断 [return_ws]返回值 Bool类型
|
||||||
|
break # 中断循环
|
||||||
|
if count < tryCount: # 判断循环次
|
||||||
|
logger.info("{0} 秒后重试,剩余次数:{1}\n".format(sleepTime, tryCount - count)) # 标准日志输出
|
||||||
|
time.sleep(sleepTime) # 脚本休眠 使用变量 [sleepTime]
|
||||||
|
if return_ws[0]: # 判断 [return_ws]返回值 Bool类型
|
||||||
|
nt_key = str(return_ws[1]) # 从 return_ws[1] 取出 -> nt_key
|
||||||
|
# logger.info("wskey转pt_key成功", nt_key) # 标准日志输出 [未启用]
|
||||||
|
logger.info("wskey转换成功") # 标准日志输出
|
||||||
|
eid = return_serch[2] # 从 return_serch 拿到 eid
|
||||||
|
ql_update(eid, nt_key) # 函数 ql_update 参数 eid JD_COOKIE
|
||||||
|
else: # 判断分支
|
||||||
|
if "WSKEY_AUTO_DISABLE" in os.environ: # 从系统变量中获取 WSKEY_AUTO_DISABLE
|
||||||
|
logger.info(str(wspin) + "账号失效") # 标准日志输出
|
||||||
|
text = "账号: {0} WsKey疑似失效".format(wspin) # 设置推送内容
|
||||||
|
else: # 判断分支
|
||||||
|
eid = return_serch[2] # 读取 return_serch[2] -> eid
|
||||||
|
logger.info(str(wspin) + "账号禁用") # 标准日志输出
|
||||||
|
ql_disable(eid) # 执行方法[ql_disable] 传递 eid
|
||||||
|
text = "账号: {0} WsKey疑似失效, 已禁用Cookie".format(wspin) # 设置推送内容
|
||||||
|
ql_send(text)
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info(str(wspin) + "账号有效") # 标准日志输出
|
||||||
|
eid = return_serch[2] # 读取 return_serch[2] -> eid
|
||||||
|
ql_enable(eid) # 执行方法[ql_enable] 传递 eid
|
||||||
|
logger.info("--------------------\n") # 标准日志输出
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("\n新wskey\n") # 标准日志分支
|
||||||
|
return_ws = getToken(ws) # 使用 WSKEY 请求获取 JD_COOKIE bool jd_ck
|
||||||
|
if return_ws[0]: # 判断 (return_ws[0]) 类型: [Bool]
|
||||||
|
nt_key = str(return_ws[1]) # return_ws[1] -> nt_key
|
||||||
|
logger.info("wskey转换成功\n") # 标准日志输出
|
||||||
|
ql_insert(nt_key) # 调用方法 [ql_insert]
|
||||||
|
logger.info("暂停{0}秒\n".format(sleepTime)) # 标准日志输出
|
||||||
|
time.sleep(sleepTime) # 脚本休眠
|
||||||
|
else: # 判断分支
|
||||||
|
logger.info("WSKEY格式错误\n--------------------\n") # 标准日志输出
|
||||||
|
logger.info("执行完成\n--------------------") # 标准日志输出
|
||||||
|
sys.exit(0) # 脚本退出
|
||||||
|
# Enjoy
|
Loading…
Reference in New Issue
Block a user