Files
3288588344-toulu/望潮代理版.py
2024-07-16 16:35:04 +08:00

637 lines
28 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
#有问题联系3288588344
#频道https://pd.qq.com/s/672fku8ge
#长期套餐大额流量电话卡办理地址https://hk.yunhaoka.cn/#/pages/micro_store/index?agent_id=669709
dlurl = '' # 记得加白
# 代理的url 不写为不用代理
print("""
二改的 谁的本我也不知道!!!
修复抽奖!!!!!!!
修复抽奖!!!!!!!
修复抽奖!!!!!!!
修复抽奖!!!!!!!
修复抽奖!!!!!!!
修复抽奖!!!!!!!
修复抽奖!!!!!!!
每天早上九点运行就行 cron:0 0 9 * * *
注册后改密码
环境变量wangchao 多号新建或&隔
手机号密码
奥特曼插件订阅3288588344 QQ频道98do10s246
""")
import hashlib
import random
import string
import time
import re
import requests
from os import environ, path
from functools import partial
from datetime import datetime
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5
import base64
import urllib.parse
def load_send():
global send
cur_path = path.abspath(path.dirname(__file__))
if path.exists(cur_path + "/SendNotify.py"):
try:
from SendNotify import send
print("加载通知服务成功!")
except Exception as e:
send = False
print(e)
print(
'''加载通知服务失败~\n请自行补全SendNotify依赖"''')
else:
send = False
print(
'''加载通知服务失败~\n请自行补全SendNotify依赖"''')
def get_environ(key, default="", output=True):
def no_read():
if output:
print(f"未填写环境变量 {key} 请添加")
#exit(0)
return default
return environ.get(key) if environ.get(key) else no_read()
def generate_random_string(length):
letters_and_digits = string.ascii_lowercase + string.digits
return ''.join(random.choice(letters_and_digits) for i in range(length))
def pd1(ck):
plaintext = ck
public_key_base64 = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQD6XO7e9YeAOs+cFqwa7ETJ+WXizPqQeXv68i5vqw9pFREsrqiBTRcg7wB0RIp3rJkDpaeVJLsZqYm5TW7FWx/iOiXFc+zCPvaKZric2dXCw27EvlH5rq+zwIPDAJHGAfnn1nmQH7wR3PCatEIb8pz5GFlTHMlluw4ZYmnOwg+thwIDAQAB"
public_key = RSA.import_key(base64.b64decode(public_key_base64))
cipher = PKCS1_v1_5.new(public_key)
cipher_text = cipher.encrypt(plaintext.encode('utf-8'))
encrypted_data_base64 = base64.b64encode(cipher_text).decode('utf-8')
cipher_text = encrypted_data_base64
url_safe_cipher_text = urllib.parse.quote(cipher_text, safe='')
return url_safe_cipher_text
class Ghdy:
def __init__(self, ck):
url = "https://passport.tmuyun.com/web/oauth/credential_auth"
url_d = 'https://vapp.taizhou.com.cn/api/zbtxz/login'
m = pd1(ck[1])
s = ck[0]
head = {
'Cache-Control': 'no-cache',
'User-Agent': 'ANDROID;9;10019;5.3.1;1.0;null;16T',
'X-REQUEST-ID': '2120678b-84a7-40f1-8c92-df789980f821',
'X-SIGNATURE': '06152b2984fd2b976e183cba4d588693c55b9ebc46814c59ac49b0e7bb63e946',
'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8',
'COOKIE': 'SESSION=YTVlNTllZmUtNjliNy00YjZiLWI0MjUtMmExZjFhYzRlYzQ5; Path=/; HttpOnly; SameSite=Lax',
'Connection': 'Keep-Alive',
'Accept-Encoding': 'gzip',
'Content-Length': '232',
}
head_d = {
"X-SESSION-ID": "6498052ebf15a44961f350e1",
"X-REQUEST-ID": "7c549049-a97b-4acb-96c6-3e2db706667d",
"X-TIMESTAMP": "1687685127765",
"X-SIGNATURE": "50e1530a02086535f5f0c2c58e7bbdea521468d3e5a2874541456da7755bbd6e",
"X-TENANT-ID": "64",
"User-Agent": "5.3.1;00000000-699e-76bc-ffff-ffff9e3d172a;Meizu 16T;Android;9;huawei",
"Cache-Control": "no-cache",
"Content-Type": "application/x-www-form-urlencoded",
"Content-Length": "67",
"Host": "vapp.taizhou.com.cn",
"Connection": "Keep-Alive",
"Accept-Encoding": "gzip"
}
data = f'client_id=10019&password={m}&phone_number={s}'
# print(data)
r = requests.post(url, headers=head, data=data)
time.sleep(2)
if r.json()['code'] == 0:
yzm = r.json()['data']['authorization_code']['code']
data_d = f'check_token=&code={yzm}&token=&type=-1&union_id='
# print(data_d)
r_d = requests.post(url=url_d, headers=head_d, data=data_d)
if r_d.json()['code'] == 0:
sessid = r_d.json()['data']['session']['id']
accid = r_d.json()['data']['account']['id']
else:
print('账号或密码错误:具体报错', r_d.text)
elif r.json()['code'] == 100:
print(r.json()['message'])
return
else:
print('未知错误具体看响应:', r.text)
return
self.account = accid
self.session = sessid
self.id_dict = {}
self.JSESSIONID = ''
self.s_JSESSIONID = ''
self.msg = ''
def login(self):
try:
time.sleep(0.5)
url = "https://xmt.taizhou.com.cn/prod-api/user-read/app/login"
headers = {
'Host': 'xmt.taizhou.com.cn',
'Connection': 'keep-alive',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Accept': '*/*',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://xmt.taizhou.com.cn/readingAward/',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
}
params = {
'id': self.account,
'sessionId': self.session,
'deviceId': '00000000-699e-76bc-ffff-ffff9e3d172a'
}
r = requests.get(url, params=params, headers=headers)
if '成功' in r.json()['msg']:
# xx = f'🚀登录成功:{r.json()["data"]["nickName"]}'
# self.msg += xx + '\n'
# print(xx)
jsessionid = r.cookies
cookies_dict = jsessionid.get_dict()
for k, y in cookies_dict.items():
self.JSESSIONID = f'{k}={y}'
elif '失败' in r.json()['msg']:
xx = f'⛔️{r.json()["msg"]}'
self.msg += xx + '\n'
print(xx)
except Exception as e:
print(e)
def get_id(self):
try:
today = datetime.today().strftime('%Y%m%d')
url = f'https://xmt.taizhou.com.cn/prod-api/user-read/list/{today}'
headers = {
'Host': 'xmt.taizhou.com.cn',
'Connection': 'keep-alive',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Accept': '*/*',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://xmt.taizhou.com.cn/readingAward/',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
'Cookie': self.JSESSIONID,
}
r = requests.get(url, headers=headers)
if '成功' in r.json()['msg']:
r_list = r.json()['data']['articleIsReadList']
id_dict = {}
for i in r_list:
id_dict[i['id']] = i['newsId']
self.id_dict = id_dict
if self.id_dict:
xx = "✅文章加载成功"
self.msg += xx + '\n'
print(xx)
elif '重新' in r.json()['msg']:
xx = f'⛔️文章加载失败:{r.json()["msg"]}'
print(xx)
self.msg += xx + '\n'
else:
xx = f'⛔️请求异常:{r.json()["msg"]}'
print(xx)
self.msg += xx + '\n'
except Exception as e:
print(e)
def look(self):
try:
for idd, new_id in self.id_dict.items():
a8 = generate_random_string(8)
b4 = generate_random_string(4)
c4 = generate_random_string(4)
d4 = generate_random_string(4)
e12 = generate_random_string(12)
request = f'{a8}-{b4}-{c4}-{d4}-{e12}'
current_timestamp = int(time.time() * 1000)
sha = f'/api/article/detail&&{self.session}&&{request}&&{current_timestamp}&&FR*r!isE5W&&64'
sha256 = hashlib.sha256()
sha256.update(sha.encode('utf-8'))
signature = sha256.hexdigest()
url = 'https://vapp.taizhou.com.cn/api/article/detail'
headers = {
'X-SESSION-ID': self.session,
'X-REQUEST-ID': f'{request}',
'X-TIMESTAMP': f'{current_timestamp}',
'X-SIGNATURE': f'{signature}',
'X-TENANT-ID': '64',
'User-Agent': '5.3.1;00000000-699e-0680-ffff-ffffc24c26a8;Xiaomi Redmi Note 8 Pro;Android;11;tencent',
'X-ACCOUNT-ID': self.session,
'Cache-Control': 'no-cache',
'Host': 'vapp.taizhou.com.cn',
'Connection': 'Keep-Alive',
'Accept-Encoding': 'gzip',
}
params = {
'id': new_id,
}
r = requests.get(url, params=params, headers=headers)
if r.json()['message'] == 'success':
xx = f'✅开始浏览《{r.json()["data"]["article"]["list_title"]}'
print(xx)
self.msg += xx + '\n'
time.sleep(3)
current_timestamp = int(time.time() * 1000)
sha = f'&&{idd}&&TlGFQAOlCIVxnKopQnW&&{current_timestamp}'
md5 = hashlib.md5()
md5.update(sha.encode('utf-8'))
signature = md5.hexdigest()
headers = {
'Host': 'xmt.taizhou.com.cn',
'Connection': 'keep-alive',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Accept': '*/*',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://xmt.taizhou.com.cn/readingAward/',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
'Cookie': self.JSESSIONID,
}
params = {
'articid': idd,
'timestamp': current_timestamp,
'signature': signature,
}
r = requests.get(
'https://xmt.taizhou.com.cn/prod-api/already-read/article',
params=params,
headers=headers,
)
if '成功' in r.json()['msg']:
xx = f'✅浏览完成'
print(xx)
self.msg += xx + '\n'
elif '重新' in r.json()['msg']:
xx = f'⛔️浏览失败:{r.json()["msg"]}'
print(xx)
self.msg += xx + '\n'
else:
xx = f'⛔️浏览异常:{r.json()["msg"]}'
print(xx)
self.msg += xx + '\n'
elif '不存在' in r.json()['msg']:
xx = f'⛔️浏览失败:{r.json()["msg"]}'
print(xx)
self.msg += xx + '\n'
else:
xx = f'⛔️浏览异常:{r.json()["msg"]}'
print(xx)
self.msg += xx + '\n'
c_headers = {
'Host': 'xmt.taizhou.com.cn',
'Connection': 'keep-alive',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Accept': '*/*',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://xmt.taizhou.com.cn/readingAward/',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
'Cookie': self.JSESSIONID,
}
today = datetime.today().strftime('%Y%m%d')
c_r = requests.get(f'https://xmt.taizhou.com.cn/prod-api/user-read-count/count/{today}', headers=c_headers)
if '成功' in c_r.json()['msg']:
xx = f'✅全部浏览完成,准备开始抽红包吧!'
print(xx)
self.msg += xx + '\n'
else:
xx = c_r.json()['msg']
print(xx)
self.msg += xx + '\n'
except Exception as e:
print(e)
def chou(self):
try:
c_headers = {
'Host': 'srv-app.taizhou.com.cn',
'Connection': 'keep-alive',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Accept': '*/*',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://srv-app.taizhou.com.cn/luckdraw/',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
'Cookie': '',
}
c_params = {
'accountId': self.account,
'sessionId': self.session,
}
c_r = requests.get('https://srv-app.taizhou.com.cn/tzrb/user/loginWC', params=c_params, headers=c_headers)
jsessionid = c_r.cookies
cookies_dict = jsessionid.get_dict()
for k, y in cookies_dict.items():
JSESSIONID = f'{k}={y}'
self.s_JSESSIONID = JSESSIONID
url = 'https://srv-app.taizhou.com.cn/tzrb/userAwardRecordUpgrade/save'
headers = {
'Host': 'srv-app.taizhou.com.cn',
'Connection': 'keep-alive',
'Content-Length': '13',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Content-type': 'application/x-www-form-urlencoded',
'Accept': '*/*',
'Origin': 'https://srv-app.taizhou.com.cn',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://srv-app.taizhou.com.cn/luckdraw/',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
'Cookie': self.s_JSESSIONID,
}
data = {
'activityId': '67',
}
r = requests.post(url, headers=headers, data=data)
if '成功' in r.json()['message']:
xx = f'✅抽奖成功'
print(xx)
self.msg += xx + '\n'
elif '明天' in r.json()['message']:
xx = f'{r.json()["message"]}'
print(xx)
self.msg += xx + '\n'
else:
print(r.text)
xx = f'⛔️{r.json()["message"]}'
print(xx)
self.msg += xx + '\n'
jl_headers = {
'Host': 'srv-app.taizhou.com.cn',
'Connection': 'keep-alive',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Accept': '*/*',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://srv-app.taizhou.com.cn/luckdraw/',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
'Cookie': self.s_JSESSIONID,
}
jl_params = {
'pageSize': '10',
'pageNum': '1',
'activityId': '67',
}
jl_r = requests.get('https://srv-app.taizhou.com.cn/tzrb/userAwardRecordUpgrade/pageList', params=jl_params,
headers=jl_headers)
if '成功' in jl_r.json()['message']:
jl_list = jl_r.json()['data']['records']
xx = '🎁抽奖记录🎁'
print(xx)
self.msg += xx + '\n'
for i in jl_list:
xx = f'{i["createTime"]}: {i["awardName"]}'
print(xx)
self.msg += xx + '\n'
send("🔔原神启动", self.msg)
else:
send("🔔原神启动", self.msg)
except Exception as e:
print(e)
def choujiang(account, dlurl):
import os
import requests
from requests.adapters import HTTPAdapter
from requests.packages.urllib3.util.retry import Retry
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5
import base64
import urllib.parse
import time
def dl():
response = requests.get(dlurl)
print(response.text)
proxies = {
'http': f'http://{response.text}',
'https': f'http://{response.text}',
}
return proxies
if dlurl != '':
try:
proxies = dl()
except Exception:
dlurl = ''
# 加密密码
def jm(password):
public_key_base64 = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQD6XO7e9YeAOs+cFqwa7ETJ+WXizPqQeXv68i5vqw9pFREsrqiBTRcg7wB0RIp3rJkDpaeVJLsZqYm5TW7FWx/iOiXFc+zCPvaKZric2dXCw27EvlH5rq+zwIPDAJHGAfnn1nmQH7wR3PCatEIb8pz5GFlTHMlluw4ZYmnOwg+thwIDAQAB"
public_key_der = base64.b64decode(public_key_base64)
key = RSA.importKey(public_key_der)
cipher = PKCS1_v1_5.new(key)
password_bytes = password.encode('utf-8')
encrypted_password = cipher.encrypt(password_bytes)
encrypted_password_base64 = base64.b64encode(encrypted_password).decode('utf-8')
url_encoded_data = urllib.parse.quote(encrypted_password_base64)
return url_encoded_data
# 签名并获取认证码
def sign(phone, password):
url_encoded_data = jm(password)
url = "https://passport.tmuyun.com/web/oauth/credential_auth"
payload = f"client_id=10019&password={url_encoded_data}&phone_number={phone}"
headers = {
'User-Agent': "ANDROID;13;10019;6.0.2;1.0;null;MEIZU 20",
'Connection': "Keep-Alive",
'Accept-Encoding': "gzip",
'Content-Type': "application/x-www-form-urlencoded",
'Cache-Control': "no-cache",
'X-SIGNATURE': "185d21c6f3e9ec4af43e0065079b8eb7f1bb054134481e57926fcc45e304b896",
}
response = requests.post(url, data=payload, headers=headers)
try:
code = response.json()['data']['authorization_code']['code']
url = "https://vapp.taizhou.com.cn/api/zbtxz/login"
payload = f"check_token=&code={code}&token=&type=-1&union_id="
headers = {
'User-Agent': "6.0.2;00000000-67e9-2a58-0000-000010724a65;Meizu MEIZU 20;Android;13;tencent;6.10.0",
'Connection': "Keep-Alive",
'Accept-Encoding': "gzip",
'Content-Type': "application/x-www-form-urlencoded",
'X-SESSION-ID': "66586b383f293a7173e4c8f4",
'X-REQUEST-ID': "110c1987-1637-4f4e-953e-e35272bb891e",
'X-TIMESTAMP': "1717072109065",
'X-SIGNATURE': "a69f171e284594a5ecc4baa1b2299c99167532b9795122bae308f27592e94381",
'X-TENANT-ID': "64",
'Cache-Control': "no-cache"
}
if dlurl == '':
response = requests.post(url, data=payload, headers=headers)
else:
response = requests.post(url, data=payload, headers=headers, proxies=proxies)
message = response.json()['message']
account_id = response.json()['data']['account']['id']
session_id = response.json()['data']['session']['id']
name = response.json()['data']['account']['nick_name']
return message, account_id, session_id, name
except Exception:
print('出错啦!')
return None, None, None, None
# 登录并获取 JSESSIONID
def login(account_id, session_id, retry_count=3):
base_url = 'https://srv-app.taizhou.com.cn'
url = f'{base_url}/tzrb/user/loginWC'
headers = {
'Host': 'srv-app.taizhou.com.cn',
'Connection': 'keep-alive',
'Pragma': 'no-cache',
'Cache-Control': 'no-cache',
'User-Agent': 'Mozilla/5.0 (Linux; Android 11; Redmi Note 8 Pro Build/RP1A.200720.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/87.0.4280.141 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;5.3.1;native_app',
'Accept': '*/*',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://srv-app.taizhou.com.cn/luckdraw/',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7'
}
params = {
'accountId': account_id,
'sessionId': session_id
}
# 创建一个包含重试策略的会话
session = requests.Session()
retries = Retry(total=5, backoff_factor=1, status_forcelist=[502, 503, 504])
session.mount('https://', HTTPAdapter(max_retries=retries))
for attempt in range(retry_count):
try:
if dlurl == '':
response = session.get(url, params=params, headers=headers, timeout=10)
else:
response = session.get(url, params=params, headers=headers, timeout=10, proxies=proxies)
if response.status_code == 200:
cookies_dict = response.cookies.get_dict()
s_JSESSIONID = '; '.join([f'{k}={v}' for k, v in cookies_dict.items()])
return s_JSESSIONID
else:
print(f"请求失败,状态码: {response.status_code}, 响应内容: {response.text}")
except requests.exceptions.RequestException as e:
print(f"请求失败 (尝试 {attempt + 1}/{retry_count}): {e}")
time.sleep(2) # 在重试前增加延迟
return None
def cj(jsessionid, retry_count=3):
url = "https://srv-app.taizhou.com.cn/tzrb/userAwardRecordUpgrade/saveUpdate"
payload = "activityId=67&sessionId=undefined&sig=undefined&token=undefined"
headers = {
'Host': 'srv-app.taizhou.com.cn',
'Connection': 'keep-alive',
'Content-Length': '63',
'User-Agent': 'Mozilla/5.0 (Linux; Android 10; MI 8 Build/QKQ1.190828.002; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/83.0.4103.101 Mobile Safari/537.36;xsb_wangchao;xsb_wangchao;6.0.2;native_app;6.10.0',
'Content-type': 'application/x-www-form-urlencoded',
'Accept': '*/*',
'Origin': 'https://srv-app.taizhou.com.cn',
'X-Requested-With': 'com.shangc.tiennews.taizhou',
'Sec-Fetch-Site': 'same-origin',
'Sec-Fetch-Mode': 'cors',
'Sec-Fetch-Dest': 'empty',
'Referer': 'https://srv-app.taizhou.com.cn/luckdraw-ra-1/',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7',
'Cookie': f'{jsessionid}'
}
if dlurl == '':
response = requests.post(url, data=payload, headers=headers, timeout=10)
else:
response = requests.post(url, data=payload, headers=headers, timeout=10, proxies=proxies)
print(response.text)
phone, password = account.split("#")
message, account_id, session_id, name = sign(phone, password)
if account_id and session_id:
mobile = phone[:3] + "*" * 4 + phone[7:]
jsessionid = login(account_id, session_id)
if jsessionid:
cj(jsessionid)
else:
print(f"获取 JSESSIONID 失败")
else:
print(f"账号 {phone} 登录失败")
if __name__ == '__main__':
print = partial(print, flush=True)
token = get_environ("wangchao", '17633912479#lxg021002')
cks = token.split("&")
print("🔔检测到{}个ck记录\n🔔".format(len(cks)))
for ck_all in cks:
ck = ck_all.split("#")
run = Ghdy(ck)
print()
run.login()
run.get_id()
run.look()
choujiang(ck_all, dlurl)