宝塔面板部署天翼网盘自动签到脚本
天翼网盘盘通过每日签到和抽奖可增加50MB-100MB空间,每月累计超4GB。通过宝塔面板部署自动化脚本,可以轻松实现每日自动签到和抽奖,详细介绍和python脚本代码如下:

1.自动签到演示效果
天翼云盘成长记录,可见2025年1月12日
网页端地址:https://cloud.189.cn/web/main/growthRecord

2.宝塔部署脚本
2.1 添加脚本路径
这个自定义修改,也可参照老白的
在目录/www/wwwroot/py
目录下新建空白文件,命名为pan.py
2.2 自动签到脚本代码
将下面的代码复制粘贴到pan.py
中,源代码来自Github @QinglongScript,取消邮箱推送
# 老白博客https://www.xcbtmw.com/31605.html 20250119修改
import time
import re
import base64
import hashlib
import rsa
import requests
# 在下面两行的引号内贴上账号(仅支持手机号)和密码
username = ""
password = ""
assert username and password, "请在此处填入有效账号和密码"
BI_RM = list("0123456789abcdefghijklmnopqrstuvwxyz")
B64MAP = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
s = requests.Session()
def int2char(a):
return BI_RM[a]
def b64tohex(a):
d = ""
e = 0
c = 0
for i in range(len(a)):
if list(a)[i] != "=":
v = B64MAP.index(list(a)[i])
if e == 0:
e = 1
d += int2char(v >> 2)
c = 3 & v
elif e == 1:
e = 2
d += int2char(c << 2 | v >> 4)
c = 15 & v
elif e == 2:
e = 3
d += int2char(c)
d += int2char(v >> 2)
c = 3 & v
else:
e = 0
d += int2char(c << 2 | v >> 4)
d += int2char(15 & v)
if e == 1:
d += int2char(c << 2)
return d
def rsa_encode(j_rsakey, string):
rsa_key = f"-----BEGIN PUBLIC KEY-----n{j_rsakey}n-----END PUBLIC KEY-----"
pubkey = rsa.PublicKey.load_pkcs1_openssl_pem(rsa_key.encode())
result = b64tohex((base64.b64encode(rsa.encrypt(f'{string}'.encode(), pubkey))).decode())
return result
def calculate_md5_sign(params):
return hashlib.md5('&'.join(sorted(params.split('&'))).encode('utf-8')).hexdigest()
def login(username, password):
urlToken = "https://m.cloud.189.cn/udb/udb_login.jsp?pageId=1&pageKey=default&clientType=wap&redirectURL=https://m.cloud.189.cn/zhuanti/2021/shakeLottery/index.html"
r = s.get(urlToken)
pattern = r"https?://[^s'"]+"
match = re.search(pattern, r.text)
if match:
url = match.group()
else:
print("没有找到url")
return None
r = s.get(url)
pattern = r"]*href="([^"]+)""
match = re.search(pattern, r.text)
if match:
href = match.group(1)
else:
print("没有找到href链接")
return None
r = s.get(href)
captchaToken = re.findall(r"captchaToken' value='(.+?)'", r.text)[0]
lt = re.findall(r'lt = "(.+?)"', r.text)[0]
returnUrl = re.findall(r"returnUrl= '(.+?)'", r.text)[0]
paramId = re.findall(r'paramId = "(.+?)"', r.text)[0]
j_rsakey = re.findall(r'j_rsaKey" value="(S+)"', r.text, re.M)[0]
s.headers.update({"lt": lt})
username = rsa_encode(j_rsakey, username)
password = rsa_encode(j_rsakey, password)
url = "https://open.e.189.cn/api/logbox/oauth2/loginSubmit.do"
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:74.0) Gecko/20100101 Firefox/76.0',
'Referer': 'https://open.e.189.cn/',
}
data = {
"appKey": "cloud",
"accountType": '01',
"userName": f"{{RSA}}{username}",
"password": f"{{RSA}}{password}",
"validateCode": "",
"captchaToken": captchaToken,
"returnUrl": returnUrl,
"mailSuffix": "@189.cn",
"paramId": paramId
}
r = s.post(url, data=data, headers=headers, timeout=5)
if r.json()['result'] == 0:
print(r.json()['msg'])
else:
print(r.json()['msg'])
redirect_url = r.json()['toUrl']
r = s.get(redirect_url)
return s
def main():
s = login(username, password)
if not s:
print("登录失败")
return
rand = str(round(time.time() * 1000))
surl = f'https://api.cloud.189.cn/mkt/userSign.action?rand={rand}&clientType=TELEANDROID&version=8.6.3&model=SM-G930K'
url = f'https://m.cloud.189.cn/v2/drawPrizeMarketDetails.action?taskId=TASK_SIGNIN&activityId=ACT_SIGNIN'
url2 = f'https://m.cloud.189.cn/v2/drawPrizeMarketDetails.action?taskId=TASK_SIGNIN_PHOTOS&activityId=ACT_SIGNIN'
url3 = f'https://m.cloud.189.cn/v2/drawPrizeMarketDetails.action?taskId=TASK_2022_FLDFS_KJ&activityId=ACT_SIGNIN'
headers = {
'User-Agent': 'Mozilla/5.0 (Linux; Android 5.1.1; SM-G930K Build/NRD90M; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/74.0.3729.136 Mobile Safari/537.36 Ecloud/8.6.3 Android/22 clientId/355325117317828 clientModel/SM-G930K imsi/460071114317824 clientChannelId/qq proVersion/1.0.6',
"Referer": "https://m.cloud.189.cn/zhuanti/2016/sign/index.jsp?albumBackupOpened=1",
"Host": "m.cloud.189.cn",
"Accept-Encoding": "gzip, deflate",
}
response = s.get(surl, headers=headers)
netdiskBonus = response.json()['netdiskBonus']
if response.json()['isSign'] == "false":
print(f"未签到,签到获得 {netdiskBonus}M 空间")
else:
print(f"已经签到过了,签到获得 {netdiskBonus}M 空间")
# 第一次抽奖
response = s.get(url, headers=headers)
if "errorCode" in response.text:
print(f"抽奖1异常: {response.text}")
else:
description = response.json()['description']
print(f"抽奖1获得 {description}")
# 第二次抽奖
response = s.get(url2, headers=headers)
if "errorCode" in response.text:
print(f"抽奖2异常: {response.text}")
else:
description = response.json()['description']
print(f"抽奖2获得 {description}")
# 第三次抽奖
response = s.get(url3, headers=headers)
if "errorCode" in response.text:
print(f"抽奖3异常: {response.text}")
else:
description = response.json()['description']
print(f"抽奖3获得 {description}")
if __name__ == "__main__":
main()
3.新建计划任务
如下图,宝塔新建计划任务,时间选择每天执行一次,粘贴下面代码即可

3.1 shell脚本内容
cd /www/wwwroot/py
source /www/server/panel/pyenv/bin/activate
python pan.py
如果没有服务器的朋友,见:https://www.52pojie.cn/thread-1999099-1-1.html
3.2 相关脚本
宝塔面板计划任务功能十分方便,可参照下面的。
有关宝塔面板与源码分享教程见文末标签和分类。
宝塔面板PHPNginxMysql-RedisMem监测并自动重启脚本
File "pan.py", line 68
pattern = r"https?://[^s'"]+" # 匹配以http或https开头的url
^
SyntaxError: invalid syntax
运行怎么提示这个错误?
好像是主题自动给我转义了,你试试更新后的
执行后提示:
File *"pan.*py",* line 57
d += int2char***(c << 2) return d def rsa_*encode***(j_rsakey*: str, message***: str) -> str***:
^SyntaxError: invalid *syntax
更新后现在提示这个。。。加了*号,不然回复不了,提示“您的请求带有不合法参数,已被网站管理员设置拦截!”。
我这次直接就关闭了邮件通知代码,测试已过,不行直接上原代码:https://juejin.cn/post/7403315879067762725。另外老哥你是linux系统吗,Windows代码是不一样的
Linux系统。算了。不想整了。
老白大佬,有没有自动签到 百度网盘的,那个可以增加百度网盘VIP积分的那个。
这个:https://github.com/gweesin/appScript-autojs
老哥百度网盘在这里:https://github.com/ElegantNorlin/CheckInService
收到,谢谢
兄弟你这回复邮件提醒,每条都有两次的
这个我还没注意老哥,我后面有时间看看
这个代码也是别人的原创老哥😂,我只是简单修改了一下,百度网盘得去找对应的接口,估计也有人弄
pattern = r"https?://[^s'"]+" # 匹配以http或https开头的url
65行这个短提示出错怎么解决?
老哥这个按理说不会报错,你是不是pan.py文件名或者路径有误。我自己日志也显示没问题,这个是github原作者代码
我现在主要用文叔叔网盘,免登录直接下载,不需要客户端
这个网盘刚开始的时候我用过,专门的用户Q群,一直以安全隐私为宣传点。当时容量空间和流量定价偏贵,对于安全隐私我还是偏向于本地硬盘,就放弃了