一、安装青龙面板
我这里在飞牛Nas上安装了青龙,安装之后开始配置
![图片[1]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/092838ec33a77ffbe0d608559ded0ba10f9d.png)
二、青龙面板配置
配置一个推送,这里我使用企业微信机器人做推送,所以配置一个机器人的key,你也可以配置其它的推送通知
![图片[2]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/09288117a0ba48fb8aa7cc37a2f4242a510a.png)
安装node.js,python,linux的依赖,好多脚本都会使用这些依赖,如果不按照很多脚本都不会能运行,所以还是按照一下
青龙依赖
NodeJs 依赖如下
————————————————————————————————————————————————————————
axios
request
canvas
cheerio
js-base64
dotenv
magic
tough-cookie
[email protected]
require
requests
date-fns
ts-md5
typescript
json5
[email protected]
crypto-js
@types/node
png-js
node-telegram-bot-api
fs
jsdom
form-data
jieba
tslib
ds
jsdom -g
prettytable
ql
common
node-jsencrypt
juejin-helper
moment
global-agent
————————————————————————————————————————————————————————
Python3 依赖如下
————————————————————————————————————————————————————————
rsa
bs4
telethon
cacheout
jieba
PyExecJS
ping3
canvas
Crypto
ds
requests
pycryptodome
————————————————————————————————————————————————————————
Linux 依赖如下
————————————————————————————————————————————————————————
bizCode
bizMsg
lxml
libc-dev
gcc
g++
libffi-dev
python3-dev
————————————————————————————————————————————————————————
这里以nodejs安装依赖为例,注意选择自动拆分
![图片[3]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/0928ad334ff26d2fd2a118954380186bc754.png)
三、青龙脚本
1.阿里云盘签到脚本
https://github.com/wang-st/aliyunSignIn.git
![图片[4]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/09288a4e0a465cf5bcfde722a2ced4a7f2c7.png)
配置阿里云盘变量refreshToken,refreshToken获取方式
![图片[5]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/0928473fbcbcaf5718502c719488fa6cc68e.png)
![图片[6]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/09280efac629a17d8fdfa7836432d2258d66.png)
2.天翼云盘签到
import time
import os
import random
import json
import base64
import hashlib
import rsa
import requests
import re
from urllib.parse import urlparse
BI_RM = list("0123456789abcdefghijklmnopqrstuvwxyz")
B64MAP = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
# 从环境变量获取账号信息
ty_usernames = os.getenv("ty_username").split('&') if os.getenv("ty_username") else []
ty_passwords = os.getenv("ty_password").split('&') if os.getenv("ty_password") else []
# 检查环境变量
if not ty_usernames or not ty_passwords:
raise ValueError("❌ 请设置环境变量 ty_username 和 ty_password")
# 组合账号信息
accounts = [{"username": u, "password": p} for u, p in zip(ty_usernames, ty_passwords)]
# 企业微信配置
QYWX_KEY = os.environ["QYWX_KEY"]
def mask_phone(phone):
"""隐藏手机号中间四位"""
return phone[:3] + "****" + phone[-4:] if len(phone) == 11 else phone[:3] + "****" + phone[-4:]
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 0 == e:
e = 1
d += int2char(v >> 2)
c = 3 & v
elif 1 == e:
e = 2
d += int2char(c << 2 | v >> 4)
c = 15 & v
elif 2 == e:
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 login(username, password):
print("🔄 正在执行登录流程...")
s = requests.Session()
try:
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)
match = re.search(r"https?://[^\s'\"]+", r.text)
if not match:
print("❌ 错误:未找到动态登录页")
return None
url = match.group()
r = s.get(url)
match = re.search(r"<a id=\"j-tab-login-link\"[^>]*href=\"([^\"]+)\"", r.text)
if not match:
print("❌ 错误:登录入口获取失败")
return None
href = match.group(1)
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_enc = rsa_encode(j_rsakey, username)
password_enc = rsa_encode(j_rsakey, password)
data = {
"appKey": "cloud",
"accountType": '01',
"userName": f"{{RSA}}{username_enc}",
"password": f"{{RSA}}{password_enc}",
"validateCode": "",
"captchaToken": captchaToken,
"returnUrl": returnUrl,
"mailSuffix": "@189.cn",
"paramId": paramId
}
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/',
}
r = s.post(
"https://open.e.189.cn/api/logbox/oauth2/loginSubmit.do",
data=data,
headers=headers,
timeout=10
)
if r.json().get('result', 1) != 0:
print(f"❌ 登录错误:{r.json().get('msg')}")
return None
s.get(r.json()['toUrl'])
print("✅ 登录成功")
return s
except Exception as e:
print(f"⚠️ 登录异常:{str(e)}")
return None
def send_wecom(msg):
if not QYWX_KEY:
print("⚠️ 未配置 QYWX_KEY 环境变量,跳过企业微信推送")
return
webhook_url = f"https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key={QYWX_KEY}"
data = {
"msgtype": "markdown",
"markdown": {
"content": msg
}
}
try:
resp = requests.post(webhook_url, json=data, timeout=10)
result = resp.json()
if result.get("errcode") == 0:
print("✅ 企业微信消息推送成功")
else:
print(f"❌ 企业微信推送失败:{result.get('errmsg', '未知错误')}")
except Exception as e:
print(f"❌ 企业微信推送异常:{str(e)}")
def main():
print("\n=============== 天翼云盘签到开始 ===============")
all_results = []
for acc in accounts:
username = acc["username"]
password = acc["password"]
masked_phone = mask_phone(username)
account_result = {"username": masked_phone, "sign": "", "lottery": ""}
print(f"\n🔔 处理账号:{masked_phone}")
# 登录流程
session = login(username, password)
if not session:
account_result["sign"] = "❌ 登录失败"
all_results.append(account_result)
continue
# 签到流程
try:
# 每日签到
rand = str(round(time.time() * 1000))
sign_url = f'https://api.cloud.189.cn/mkt/userSign.action?rand={rand}&clientType=TELEANDROID&version=8.6.3&model=SM-G930K'
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",
}
resp = session.get(sign_url, headers=headers).json()
if resp.get('isSign') == "false":
account_result["sign"] = f"✅ +{resp['netdiskBonus']}M"
else:
account_result["sign"] = f"⏳ 已签到+{resp['netdiskBonus']}M"
# 单次抽奖(原第一次抽奖)
time.sleep(random.randint(2, 5))
lottery_url = 'https://m.cloud.189.cn/v2/drawPrizeMarketDetails.action?taskId=TASK_SIGNIN&activityId=ACT_SIGNIN'
resp = session.get(lottery_url, headers=headers).json()
if "errorCode" in resp:
account_result["lottery"] = f"❌ {resp.get('errorCode')}"
else:
prize = resp.get('prizeName') or resp.get('description')
account_result["lottery"] = f"🎁 {prize}"
except Exception as e:
account_result["sign"] = "❌ 操作异常"
account_result["lottery"] = f"⚠️ {str(e)}"
all_results.append(account_result)
print(f" {account_result['sign']} | {account_result['lottery']}")
# 生成汇总表格
table = "### ⛅ 天翼云盘签到汇总\n\n"
table += "| 账号 | 签到结果 | 每日抽奖 |\n"
table += "|:-:|:-:|:-:|\n"
for res in all_results:
table += f"| {res['username']} | {res['sign']} | {res['lottery']} |\n"
# 发送汇总推送
# send_pushdeer(table)
send_wecom(table)
print("\n✅ 所有账号处理完成!")
if __name__ == "__main__":
main()
![图片[7]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/09289ff6a68c3aa20f85cce3b9676122c67c.png)
添加定时任务
![图片[8]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/0928692ccbc49454f3a18b42b85d1a3643fe.png)
配置天翼云的账号和密码
![图片[9]-玩转青龙面板,让签到不再手动,阿里云盘签到,天翼云盘签到-乘风资源网](https://c17bd80.webp.li/images/2025/0928bb64afe782d82e94c6f49c059718a20a.png)
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容