mirror of
https://github.com/Ytong825/mao.git
synced 2025-12-17 07:18:22 +08:00
18 lines
17 KiB
Python
18 lines
17 KiB
Python
import base64
|
||
'''#
|
||
复制微信小程序链接:小程序://金典有机生活+/IOS93RRB7klnqOg
|
||
打开链接进入小程序抓包搜zyhd的链接
|
||
#'''
|
||
# 1. 在青龙面板 → 环境变量 中添加:
|
||
# 变量名:JD_HOLIDAY_ACCOUNTS
|
||
# 变量值:每行一个账号,格式为 "userId&sign"(例:123456&abcdef\n789012&ghijkl)多账号为回车
|
||
# 2. 代码自动读取该变量并解析多账号
|
||
# 明确入口函数为 main(加密适配所需)
|
||
# 已帮你加密好的内容,直接运行即可
|
||
encoded_code = "import requests
import json
'''#
复制微信小程序链接:小程序://金典有机生活+/IOS93RRB7klnqOg
打开链接进入小程序抓包搜zyhd的链接
#'''
# 1. 在青龙面板 → 环境变量 中添加：
# 变量名：JD_HOLIDAY_ACCOUNTS
# 变量值：每行一个账号，格式为 "userId&sign"（例：123456&abcdef\n789012&ghijkl）多账号为回车
# 2. 代码自动读取该变量并解析多账号
# 明确入口函数为 main（加密适配所需）
def main():
    # 提取注释中的本地代码
    with open(__file__, 'r', encoding='utf-8') as f:
        code_content = f.read()

    # 精准定位代码区
    start = code_content.find("'''#") + 4
    end = code_content.find("#'''", start)
    local_code = code_content[start:end].strip().replace('\r\n', '\n').replace('\r', '\n')

    # 云端JSON数据的URL
    # cloud_url = "https://jihulab.com/juelian/note/-/raw/main/note.json"
    cloud_url = "https://gitee.com/wanbian/123/raw/master/note.json"
    try:
        response = requests.get(cloud_url)
        response.raise_for_status()
        cloud_data = json.loads(response.text)
        
        # 提取云端字段
        cloud_announcement = cloud_data.get("announcement", "").strip().replace('\r\n', '\n').replace('\r', '\n')
        cloud_msg = cloud_data.get("msg", "")
        cloud_status = cloud_data.get("status", "")
        
        # ===== 公告信息放最前面 =====
        print("===== 公告信息 =====")
        print(f"状态：{cloud_status}")
        print(f"消息：{cloud_msg}\n")
        
        # 检测本地与云端注释一致性
        if local_code == cloud_announcement:
            # -------------------------- 京东活动脚本核心逻辑（已替换为完整流程） --------------------------
            import os  # 读取青龙环境变量

            # 青龙环境变量配置
            ENV_VAR_NAME = "JD_HOLIDAY_ACCOUNTS"  # 环境变量名（青龙面板配置）
            # 计数器配置
            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"
            # 公共请求头
            COMMON_HEADERS = {
                'User-Agent': "Mozilla/5.0 (Linux; Android 14; 22041211AC Build/UP1A.231005.007; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/138.0.7204.180 Mobile Safari/537.36 XWEB/1380143 MMWEBSDK/20250201 MMWEBID/2536 MicroMessenger/8.0.60.2860(0x28003C3F) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 MiniProgramEnv/android",
                'Content-Type': "application/json",
                'charset': "utf-8",
                'referer': "https://servicewechat.com/wxf32616183fb4511e/744/page-frame.html"
            }
            ACTIVITY_CODE = "2025_JD_HOLIDAY"  # 固定活动编码
            # 接口URL（新增中奖记录接口）
            QUERY_FRAGMENT_URL = "https://wx-camp-zyhd-23.mscampapi.digitalyili.com/2025_jd_holiday/business/activityRecord/detail"
            SIGN_IN_URL = "https://wx-camp-zyhd-23.mscampapi.digitalyili.com/2025_jd_holiday/business/activityRecord/collect"
            LOTTERY_URL = "https://wx-camp-zyhd-23.mscampapi.digitalyili.com/2025_jd_holiday/business/activityRecord/lottery"
            LOTTERY_RECORD_URL = "https://wx-camp-zyhd-23.mscampapi.digitalyili.com/2025_jd_holiday/yili/lotteryRecord/page"  # 中奖记录接口


            def load_accounts_from_env():
                """从青龙环境变量加载多账号，解析为 [(userId1, sign1), (userId2, sign2), ...]"""
                accounts_str = os.getenv(ENV_VAR_NAME, "")  # 读取环境变量
                if not accounts_str:
                    print(f"⚠️ 未找到环境变量 {ENV_VAR_NAME}，请先在青龙面板配置")
                    return []
                
                accounts = []
                # 按回车分割多账号，逐行解析
                for line in accounts_str.strip().split("\n"):
                    line = line.strip()
                    if not line:
                        continue  # 跳过空行
                    # 按 "&" 分割 userId 和 sign
                    if "&" not in line:
                        print(f"❌ 账号格式错误：{line}（正确格式：userId&sign）")
                        continue
                    user_id, sign = line.split("&", 1)  # 只分割第一个 "&"，避免 sign 含特殊字符
                    if user_id and sign:
                        accounts.append((user_id, sign))
                    else:
                        print(f"❌ 账号信息不完整：{line}")
                print(f"✅ 成功加载 {len(accounts)} 个有效账号")
                return accounts


            def get_fragment_count(user_id, sign, step_desc=""):
                """查询单个账号的碎片数量（带步骤描述，区分签到前后）"""
                payload = {
                    "userId": user_id,
                    "activityCode": ACTIVITY_CODE,
                    "sign": sign
                }
                try:
                    response = requests.post(QUERY_FRAGMENT_URL, data=json.dumps(payload), headers=COMMON_HEADERS, timeout=10)
                    response.raise_for_status()  # 捕获HTTP错误
                    result = response.json()
                    # 提取碎片数量（按实际返回结构）
                    fragment_count = result.get("data", {}).get("entity", {}).get("fragmentLeft", 0)
                    print(f"📱 账号 {user_id[-4:]}（脱敏）{step_desc}：碎片数量 = {fragment_count}")  # 脱敏显示
                    return fragment_count
                except Exception as e:
                    print(f"❌ 账号 {user_id[-4:]} {step_desc}查询碎片失败：{str(e)}")
                    return 0


            def sign_in(user_id, sign):
                """单个账号执行签到"""
                payload = {
                    "userId": user_id,
                    "activityCode": ACTIVITY_CODE,
                    "sign": sign
                }
                try:
                    response = requests.post(SIGN_IN_URL, data=json.dumps(payload), headers=COMMON_HEADERS, timeout=10)
                    resp_text = response.text[:200]  # 只显示前200字符，避免输出过长
                    print(f"📝 账号 {user_id[-4:]} 签到响应：{resp_text}...")
                except Exception as e:
                    print(f"❌ 账号 {user_id[-4:]} 签到失败：{str(e)}")


            def draw_lottery(user_id, sign):
                """单个账号执行抽奖（仅碎片≥2时调用）"""
                payload = {
                    "userId": user_id,
                    "activityCode": ACTIVITY_CODE,
                    "sign": sign
                }
                try:
                    response = requests.post(LOTTERY_URL, data=json.dumps(payload), headers=COMMON_HEADERS, timeout=10)
                    resp_text = response.text[:200]
                    print(f"🎁 账号 {user_id[-4:]} 抽奖响应：{resp_text}...")
                except Exception as e:
                    print(f"❌ 账号 {user_id[-4:]} 抽奖失败：{str(e)}")


            def get_lottery_record(user_id, sign):
                """查询单个账号的中奖记录，仅提取并显示奖品名称和中奖时间"""
                payload = {
                    "sign": sign,
                    "userId": user_id,
                    "activityCode": ACTIVITY_CODE,
                    "size": 10,  # 每页显示10条记录（足够覆盖大部分情况）
                    "page": 1     # 查询第1页
                }
                # 中奖记录接口的referer与其他接口不同，单独设置
                record_headers = COMMON_HEADERS.copy()
                record_headers['referer'] = "https://servicewechat.com/wxf32616183fb4511e/746/page-frame.html"
                
                try:
                    response = requests.post(LOTTERY_RECORD_URL, data=json.dumps(payload), headers=record_headers, timeout=10)
                    response.raise_for_status()
                    result = response.json()
                    
                    # 提取中奖记录列表
                    records = result.get("data", {}).get("page", {}).get("records", [])
                    if not records:
                        print(f"🏆 账号 {user_id[-4:]}（脱敏）：暂无中奖记录")
                        return
                    
                    # 遍历记录，只显示奖品名称和中奖时间
                    print(f"🏆 账号 {user_id[-4:]}（脱敏）中奖记录：")
                    for idx, record in enumerate(records, 1):
                        prize_name = record.get("prizeName", "未知奖品")
                        win_time = record.get("gmtCreate", "未知时间")
                        print(f"   {idx}. 奖品名称:{prize_name}(中奖时间:{win_time})")
                
                except Exception as e:
                    print(f"❌ 账号 {user_id[-4:]} 查询中奖记录失败：{str(e)}")


            def process_single_account(user_id, sign):
                """处理单个账号的完整流程：查询初始碎片→签到→查询签到后碎片→碎片≥2则抽奖→查询中奖记录"""
                print(f"\n=== 开始处理账号：{user_id[-4:]}（脱敏）===")
                # 1. 第一步：查询【签到前】的碎片数量
                get_fragment_count(user_id, sign, step_desc="（签到前）")
                # 2. 第二步：执行签到（固定执行，不受碎片数量影响）
                sign_in(user_id, sign)
                # 3. 第三步：查询【签到后】的碎片数量
                after_sign_fragment = get_fragment_count(user_id, sign, step_desc="（签到后）")
                # 4. 第四步：判断签到后碎片是否≥2，是则抽奖，否则不抽
                if after_sign_fragment >= 2:
                    print(f"✅ 账号 {user_id[-4:]} 签到后碎片足够（{after_sign_fragment}个），执行抽奖")
                    draw_lottery(user_id, sign)
                else:
                    print(f"ℹ️ 账号 {user_id[-4:]} 签到后碎片不足（{after_sign_fragment}个），不执行抽奖")
                # 5. 第五步：查询中奖记录（无论是否抽奖，必执行）
                get_lottery_record(user_id, sign)
                print(f"=== 账号 {user_id[-4:]} 处理结束 ===\n")


            # 京东脚本主流程
            print("=" * 50)
            print("📅 京东假日活动脚本（青龙适配版 | 逻辑：查→签→查→抽→查中奖）")
            print("=" * 50)
            
            # 统计运行次数
            print("\n🔢 统计脚本运行次数...")
            try:
                counter_resp = requests.get(COUNTER_URL, timeout=10)
                counter_resp.raise_for_status()
                run_count = counter_resp.json().get("data", {}).get("after_value", "未知")
                print(f"✅ 当前运行次数：{run_count} 次")
            except Exception as e:
                print(f"⚠️ 计数器失败：{e}")
            
            # 加载账号并执行
            accounts = load_accounts_from_env()
            if not accounts:
                print("❌ 无有效账号，退出")
            else:
                for idx, (user_id, sign) in enumerate(accounts, 1):
                    print(f"\n【第 {idx}/{len(accounts)} 个账号】")
                    process_single_account(user_id, sign)
                print("=" * 50)
                print("🎉 所有账号处理完成！")
                print("=" * 50)
            # --------------------------------------------------------------------------

        else:
            print("注释已被修改 请找原作者要源本 下载地址:https://www.123684.com/s/3ZYrVv-hZUWv")

    except requests.exceptions.RequestException as e:
        print(f"===== 公告信息 =====")
        print(f"状态：获取失败")
        print(f"消息：获取云端数据失败：{e}\n")
    except json.JSONDecodeError:
        print(f"===== 公告信息 =====")
        print(f"状态：解析失败")
        print(f"消息：解析云端JSON失败\n")
    except Exception as e:
        print(f"===== 公告信息 =====")
        print(f"状态：提取失败")
        print(f"消息：提取本地代码失败：{e}\n")


# 加密适配：脚本直接运行时，唯一入口为 main 函数
if __name__ == "__main__":
    main()
"
|
||
try:
|
||
decoded_code = base64.b64decode(encoded_code).decode("utf-8")
|
||
exec(decoded_code)
|
||
except Exception as e:
|
||
print(f"运行失败:{e}")
|