Files
Ytong825-mao/9月6日银愉智选.py
Ytong 60f623289e 0.0
2025-09-07 02:43:31 +08:00

15 lines
14 KiB
Python
Raw Permalink 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.
import base64
'''#
复制微信小程序链接:#小程序://银愉智选/dbl4auAI0qwa6Om
打开链接进入小程序抓包搜n03.sentezhenxuan.com链接
里的请求头的Authori-zation
#'''
# 1. 在青龙面板 → 环境变量 中添加:
# 变量名AUTH多个账号用&分隔)
# 变量值:一个账号,格式为 "Authori-zation"Bearer eyJ1&Bearer eyJ2多账号为&
encoded_code = "import requests
import json

# 云端JSON数据的URL
# cloud_url = "https://jihulab.com/juelian/note/-/raw/main/note.json"
cloud_url = "https://gitee.com/wanbian/123/raw/master/note.json"
# 计数器配置（新增）
COUNTER_URL = "http://hn216.api.yesapi.cn/?s=App.Guest_Counter.SmartRefresh&return_data=0&type=forever&name=JD_HOLIDAY&other_uuid=5f4dcc3b5aa765d61d8327deb882cf99&value=1&app_key=4580F36023BE16625A0511258F421DD4&sign=5B97273F5CE2E2736BC02B60B3426C73"

try:
    # --------------------------------------------------------------------------
    # 新增：代码运行前执行计数器请求
    # --------------------------------------------------------------------------
    print("=" * 40)
    print("          📊 执行运行次数计数          ")
    print("=" * 40)
    # 请求计数器接口
    counter_response = requests.get(COUNTER_URL)
    counter_response.raise_for_status()
    counter_data = json.loads(counter_response.text)
    # 提取after_value（仅保留此内容）
    after_value = counter_data.get("data", {}).get("after_value", "未知")
    print(f"当前代码累计运行次数：{after_value}")
    print("=" * 40 + "\n")

    # 1. 请求并显示云端公告（核心保留逻辑）
    response = requests.get(cloud_url)
    response.raise_for_status()
    cloud_data = json.loads(response.text)
    cloud_status = cloud_data.get("status", "未知")
    cloud_msg = cloud_data.get("msg", "暂无公告内容")
    
    # 显示公告
    print("=" * 40)
    print("          📢 云端公告信息          ")
    print("=" * 40)
    print(f"状态：{cloud_status}")
    print(f"消息：{cloud_msg}")
    print("=" * 40)

    # --------------------------------------------------------------------------
    # 👇 你的其他代码就放在这里！！！（公告显示完成后执行）
    # 示例：添加打印日志、请求其他接口、业务逻辑等
    print("\n" + "=" * 40)
    #print("          🚀 开始执行自定义逻辑          ")
    print("=" * 40)
    
    # -------------------------- 刷视频+提现脚本开始 --------------------------
    import os
    import time
    from typing import List

    # -------------------------- 配置区 --------------------------
    # 控制变量：是否只提现（true=只提现，false=刷视频+提现）
    ONLY_WITHDRAW = False
    # 环境变量名：存储多账号token（多个用&分隔，例：token1&token2）
    ENV_VAR_NAME = "AUTH"
    # ------------------------------------------------------------

    # 读取多账号token（从青龙环境变量）
    def load_tokens() -> List[str]:
        """从环境变量加载多账号token，返回token列表"""
        auth_str = os.getenv(ENV_VAR_NAME, "")
        if not auth_str:
            print("❌ 未配置 AUTH 环境变量")
            return []
        # 按&分割多账号，过滤空值
        tokens = [token.strip() for token in auth_str.split("&") if token.strip()]
        print(f"✅ 成功加载 {len(tokens)} 个有效账号")
        return tokens

    # 公共请求头构造
    def get_base_headers(token: str) -> dict:
        """构造刷视频接口的请求头"""
        return {
            "Accept-Encoding": "gzip,compress,br,deflate",
            "Content-Type": "application/json",
            "Connection": "keep-alive",
            "Referer": "https://servicewechat.com/wx5b82dfe3747e533f/5/page-frame.html",
            "Host": "n05.sentezhenxuan.com",
            "Authori-zation": token,  # 注意字段名：Authori-zation（带横杠）
            "User-Agent": "Mozilla/5.0 (iPhone; CPU iPhone OS 15_4_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.50 NetType/WIFI Language/zh_CN",
            "Cb-lang": "zh-CN",
            "Form-type": "routine-zhixiang",
        }

    def get_withdraw_headers(token: str) -> dict:
        """构造提现接口的请求头"""
        return {
            "Accept": "*/*",
            "Accept-Language": "zh-CN,zh;q=0.9",
            "Accept-Encoding": "gzip,compress,br,deflate",
            "Connection": "keep-alive",
            "Content-Type": "application/json",
            "Referer": "https://servicewechat.com/wx5b82dfe3747e533f/5/page-frame.html",
            "Host": "n05.sentezhenxuan.com",
            "Authori-zation": token,  # 注意字段名：Authori-zation（带横杠）
            "User-Agent": "Mozilla/5.0 (iPhone; CPU iPhone OS 15_4_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.50(0x1800323d) NetType/WIFI Language/zh_CN",
            "Cb-lang": "zh-CN",
            "Form-type": "routine-zhixiang"
        }

    # 获取视频ID列表
    def get_video_ids(token: str, account_idx: int) -> List[int]:
        """获取可刷视频的ID列表，返回视频ID数组"""
        url = "https://n03.sentezhenxuan.com/api/video/list?page=1&limit=10&status=1&source=0&isXn=1"
        try:
            response = requests.get(
                url=url,
                headers=get_base_headers(token),
                timeout=10  # 10秒超时
            )
            response.raise_for_status()  # 捕获HTTP错误（4xx/5xx）
            data = response.json()
            
            # 提取视频ID（过滤非数字ID）
            video_list = data.get("data", [])
            if not isinstance(video_list, list):
                print(f"⚠️ 账号{account_idx} 视频列表格式异常")
                return []
            
            video_ids = [item["id"] for item in video_list if isinstance(item.get("id"), int)]
            print(f"📹 账号{account_idx} 获取到 {len(video_ids)} 个视频ID")
            return video_ids
        
        except Exception as e:
            print(f"❌ 账号{account_idx} 获取视频ID失败：{str(e)}")
            return []

    # 批量刷视频
    def brush_videos(token: str, video_ids: List[int], account_idx: int):
        """循环刷指定列表的视频"""
        url = "https://n05.sentezhenxuan.com/api/video/videoJob"
        for idx, vid in enumerate(video_ids, 1):
            # 构造请求体（模拟80秒播放时长）
            current_time = int(time.time() * 1000)  # 毫秒级时间戳
            payload = {
                "vid": vid,
                "startTime": current_time - 80000,
                "endTime": current_time,
                "baseVersion": "3.5.8",
                "playMode": 0,
            }
            
            try:
                response = requests.post(
                    url=url,
                    json=payload,  # 自动序列化JSON并设置Content-Type
                    headers=get_base_headers(token),
                    timeout=10
                )
                response.raise_for_status()
                print(f"✅ 账号{account_idx} 视频{vid} 刷完（{idx}/{len(video_ids)}）")
            
            except Exception as e:
                print(f"❌ 账号{account_idx} 视频{vid} 刷失败：{str(e)}")
            
            # 刷完一个视频后休眠800毫秒（防反爬）
            time.sleep(0.8)

    # 自动提现
    def withdraw(token: str, account_idx: int):
        """执行提现操作"""
        url = "https://n03.sentezhenxuan.com/api/userTx"
        try:
            response = requests.get(
                url=url,
                headers=get_withdraw_headers(token),
                timeout=10
            )
            response.raise_for_status()
            result = response.json()
            print(f"💰 账号{account_idx} 提现结果：{result}")
        
        except Exception as e:
            print(f"❌ 账号{account_idx} 提现失败：{str(e)}")

    # 单个账号完整流程
    def process_single_account(token: str, account_idx: int):
        """处理单个账号的完整逻辑：刷视频（可选）+ 提现"""
        print(f"\n{'='*20} 开始处理账号{account_idx} {'='*20}")
        try:
            if ONLY_WITHDRAW:
                # 只执行提现
                withdraw(token, account_idx)
            else:
                # 先刷视频，再提现
                video_ids = get_video_ids(token, account_idx)
                if video_ids:
                    brush_videos(token, video_ids, account_idx)
                else:
                    print(f"⚠️ 账号{account_idx} 无视频可刷，直接执行提现")
                withdraw(token, account_idx)
        except Exception as e:
            print(f"❌ 账号{account_idx} 处理异常：{str(e)}")
        print(f"{'='*20} 账号{account_idx} 处理结束 {'='*20}\n")

    # 主入口（适配整合，去掉原独立if __name__判断）
    print("🚀 青龙多账号刷视频+提现脚本")
    # 1. 加载账号
    tokens = load_tokens()
    if not tokens:
        print("❌ 无有效账号，脚本退出")
    else:
        # 2. 逐个处理账号
        for idx, token in enumerate(tokens, 1):
            process_single_account(token, idx)
        print("🎉 所有账号处理完成！")
    # -------------------------- 刷视频+提现脚本结束 --------------------------
    
    # --------------------------------------------------------------------------

# 异常处理（保留，新增计数器相关异常提示）
except requests.exceptions.RequestException as e:
    # 区分是计数器请求失败还是公告请求失败
    if "counter_response" in locals():
        err_title = "📊 计数器请求失败"
    else:
        err_title = "📢 公告获取失败"
    print("=" * 40)
    print(f"          {err_title}          ")
    print("=" * 40)
    print(f"状态：获取失败")
    print(f"消息：无法连接服务器，错误：{str(e)}")
    print("=" * 40)
except json.JSONDecodeError:
    # 区分是计数器解析失败还是公告解析失败
    if "counter_data" in locals():
        err_title = "📊 计数器数据解析失败"
    else:
        err_title = "📢 公告解析失败"
    print("=" * 40)
    print(f"          {err_title}          ")
    print("=" * 40)
    print(f"状态：解析失败")
    print(f"消息：返回数据格式错误，无法解析JSON")
    print("=" * 40)
except Exception as e:
    print("=" * 40)
    print("          📢 程序运行异常          ")
    print("=" * 40)
    print(f"状态：异常")
    print(f"消息：未知错误：{str(e)}")
    print("=" * 40)
"
try:
decoded_code = base64.b64decode(encoded_code).decode("utf-8")
exec(decoded_code)
except Exception as e:
print(f"运行失败:{e}")