WWW.YOUINFO.SITE
标签聚合 复活

/tag/复活

LinuxDo 最新话题 · 2026-06-11 03:13:36+08:00 · tech

这些应用很少做覆盖更新的,都是全新APP 不过更新之后连用户数据都丢失了还是第一次见,大部分都是绑定设备ID的 别问是什么网站,去代码里找 破解版没有破解 只能靠咱们手搓 界面参考: 复制以下代码,直接到powershell运行就可以安装到桌面了 如果电脑不匹配,用不了的,可以让AI直接帮你把Python代码写出来 $path = "$HOME\Desktop\invite_tool.py"; $code = @' import os import sys import subprocess def bootstrap_dependencies(): required_libs = {"requests": "requests", "Crypto": "pycryptodome"} missing_libs = [] for module_name, pip_name in required_libs.items(): try: __import__(module_name) except ImportError: missing_libs.append(pip_name) if missing_libs: if "pycryptodome" in missing_libs and sys.platform.startswith("win"): subprocess.run([sys.executable, "-m", "pip", "uninstall", "-y", "crypto"], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL) subprocess.run([sys.executable, "-m", "pip", "uninstall", "-y", "pycryptodome"], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL) for lib in missing_libs: try: subprocess.run([sys.executable, "-m", "pip", "install", "--upgrade", "pip"], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL) subprocess.run([sys.executable, "-m", "pip", "install", lib], check=True) except Exception: sys.exit(1) bootstrap_dependencies() import base64 import hashlib import json import random import threading import time import tkinter as tk from tkinter import messagebox, ttk from concurrent.futures import ThreadPoolExecutor, as_completed from dataclasses import dataclass from typing import Any import requests import urllib3 from Crypto.Cipher import AES, PKCS1_v1_5 from Crypto.PublicKey import RSA from Crypto.Util.Padding import unpad urllib3.disable_warnings() requests.packages.urllib3.disable_warnings() PUBLIC_KEY_RAW = ( "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCgsH82stbCUaE1fTsotU0E2HWU9uQz496NFKgjjHBn" "Bzqk9YtYcowNFxaOz6G5Q3bw5j/+0+iAD58/n99ENjFkipiulu30eRiUpHUVFyc+EJ14FLKIXNksQWTu" "AivCkIYcDNP42in1nyjdXrpps7klCMm9MeAz8Mm+k9r1MGVJsQIDAQAB" ) class AtomicCounter: def __init__(self) -> None: self._value = 0 self._lock = threading.Lock() def inc(self) -> int: with self._lock: self._value += 1 return self._value @property def value(self) -> int: with self._lock: return self._value @dataclass(slots=True) class ApiConfig: base_url: str = "https://34.81.42.86:2242" macct: str = "sf42" ver: str = "1.0" os: str = "2" user_agent: str = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/145.0.0.0 Safari/537.36" accept: str = "application/json,*/*" content_type: str = "application/json; charset=UTF-8" timeout: float = 8.0 aes_key: str = "GcgzsKdDZTumABNz7uujrCfPIk9TQ355" @dataclass(slots=True) class ApiResult: code: int msg: str data: Any class ApiClient: def __init__(self, config: ApiConfig, public_key: str) -> None: self.config = config self.session = requests.Session() self.session.verify = False self._aes_key = config.aes_key.encode("utf-8") self._public_key = RSA.import_key(self._load_public_key(public_key)) self.session.headers.update({ "user-agent": config.user_agent, "accept": config.accept, "content-type": config.content_type, "ver": config.ver, "os": config.os, "macct": config.macct, }) def close(self) -> None: self.session.close() def set_token(self, token: str | None) -> None: if token is None: self.session.headers.pop("token", None) else: self.session.headers.update({"token": token}) def post_plain(self, path: str, payload: dict[str, Any], params: dict[str, Any] | None = None) -> ApiResult: return self._post(path, payload, params=params) def post_rsa(self, path: str, payload: dict[str, Any]) -> ApiResult: return self._post(path, {"encrypt": self.rsa_encrypt_payload(payload)}) def rsa_encrypt_payload(self, payload: dict[str, Any]) -> str: plain = json.dumps(payload, ensure_ascii=False, separators=(",", ":")).encode("utf-8") cipher = PKCS1_v1_5.new(self._public_key) chunk_size = self._public_key.size_in_bytes() - 11 encrypted = bytearray() for i in range(0, len(plain), chunk_size): encrypted.extend(cipher.encrypt(plain[i : i + chunk_size])) return base64.b64encode(bytes(encrypted)).decode("ascii") def decrypt_response_text(self, raw_text: str) -> dict[str, Any]: text = raw_text.strip() if text.startswith('"') and text.endswith('"'): text = json.loads(text) cipher = AES.new(self._aes_key, AES.MODE_ECB) plain = unpad(cipher.decrypt(base64.b64decode(text)), AES.block_size).decode("utf-8") return json.loads(plain) def _post(self, path: str, payload: dict[str, Any], params: dict[str, Any] | None = None) -> ApiResult: response = self.session.post( f"{self.config.base_url.rstrip('/')}/{path.lstrip('/')}", params=params, json=payload, timeout=self.config.timeout, ) response.raise_for_status() result = self.decrypt_response_text(response.text) return ApiResult(code=result["code"], msg=result["msg"], data=result["data"]) @staticmethod def _load_public_key(raw: str) -> str: if "BEGIN PUBLIC KEY" in raw or "BEGIN RSA PUBLIC KEY" in raw: return raw b64 = "".join(raw.split()) lines = [b64[i : i + 64] for i in range(0, len(b64), 64)] return "-----BEGIN PUBLIC KEY-----\n" + "\n".join(lines) + "\n-----END PUBLIC KEY-----\n" class ApiService: def __init__(self, client: ApiClient) -> None: self.client = client def login(self, mac: str) -> ApiResult: payload = { "mac": mac, "tips": hashlib.md5(f"{self.client.config.macct}{mac}1".encode("utf-8")).hexdigest(), "os": "1", } return self.client.post_rsa("/front/cluser/c/user/mac/login", payload) def bind_refer(self, code: str) -> ApiResult: return self.client.post_plain("/front/cluser/c/user/bind/refer", {}, params={"code": code}) def make_uid() -> str: raw = f"{time.time()}{random.random()}{threading.get_ident()}" uid = hex(hash(raw))[2:] return uid if len(uid) == 16 else f"1{uid[:15]}" def do_invite(refer_code: str, counter: AtomicCounter, total: int, log_callback) -> tuple[bool, str]: client = None try: client = ApiClient(ApiConfig(), PUBLIC_KEY_RAW) api = ApiService(client) uid = make_uid() data = api.login(uid).data client.set_token(data["token"]) result = api.bind_refer(refer_code) success = result.code == 0 msg = result.msg except Exception as ex: success = False msg = str(ex) finally: if client is not None: client.close() n = counter.inc() log_callback(n, total, success, msg) return success, msg class App: def __init__(self, root: tk.Tk) -> None: self.root = root self.root.title("琉璃暗匣 - 极速推广控制台") self.root.geometry("540x440") self.root.resizable(False, False) self.root.configure(bg="#F5F7FA") self.style = ttk.Style() self.style.theme_use("clam") # 现代化视觉样式配置 self.style.configure("TFrame", background="#F5F7FA") self.style.configure("Card.TFrame", background="#FFFFFF", relief="flat") self.style.configure("TLabel", background="#FFFFFF", font=("Microsoft YaHei", 10), foreground="#2C3E50") self.style.configure("Title.TLabel", background="#F5F7FA", font=("Microsoft YaHei", 12, "bold"), foreground="#34495E") self.style.configure("Warning.TLabel", background="#F5F7FA", font=("Microsoft YaHei", 9), foreground="#E74C3C") self.style.configure("TButton", font=("Microsoft YaHei", 10, "bold"), padding=10, background="#E0E6ED", foreground="#2C3E50", borderwidth=0) self.style.map("TButton", background=[("active", "#D4DBE4")]) self.style.configure("VIP.TButton", background="#FF4757", foreground="white") self.style.map("VIP.TButton", background=[("active", "#FF6B81")]) self.style.configure("Gold.TButton", background="#2ED573", foreground="white") self.style.map("Gold.TButton", background=[("active", "#7BED9F")]) self.running = False self.create_widgets() def create_widgets(self) -> None: # 顶部标题与提示 header_frame = ttk.Frame(self.root) header_frame.pack(fill="x", padx=20, pady=(15, 5)) ttk.Label(header_frame, text="✨ 极速推广控制台", style="Title.TLabel").pack(anchor="w") ttk.Label(header_frame, text="💡 温馨提示:由于网络非对称延迟,当前进度与实际可能存在微小偏差\n具体奖励到账情况,请以 APP 或网页端实际显示为准~", style="Warning.TLabel").pack(anchor="w", pady=(5, 0)) # 核心卡片区 (白色背景,增加呼吸感) card_frame = ttk.Frame(self.root, style="Card.TFrame") card_frame.pack(fill="x", padx=20, pady=10, ipadx=15, ipady=15) # 邀请码输入 ttk.Label(card_frame, text="专属邀请码:").grid(row=0, column=0, sticky="w", pady=(0, 15)) self.code_var = tk.StringVar(value="") self.entry_code = ttk.Entry(card_frame, textvariable=self.code_var, font=("Consolas", 12, "bold"), width=20, justify="center") self.entry_code.grid(row=0, column=1, sticky="w", pady=(0, 15), padx=10) # 线程设置 ttk.Label(card_frame, text="并发线程数:").grid(row=1, column=0, sticky="w") self.workers_var = tk.StringVar(value="10") self.workers_spin = ttk.Spinbox(card_frame, from_=1, to=50, width=5, textvariable=self.workers_var, font=("Consolas", 11)) self.workers_spin.grid(row=1, column=1, sticky="w", padx=10) # 按钮区 btn_frame = ttk.Frame(self.root) btn_frame.pack(fill="x", padx=20, pady=5) self.btn_vip = ttk.Button(btn_frame, text="💎 刷 180天会员 (100人)", style="VIP.TButton", command=lambda: self.start_task(100)) self.btn_vip.pack(side="left", expand=True, fill="x", padx=(0, 5)) self.btn_gold = ttk.Button(btn_frame, text="💰 刷 1000金币 (200人)", style="Gold.TButton", command=lambda: self.start_task(200)) self.btn_gold.pack(side="right", expand=True, fill="x", padx=(5, 0)) # 进度与日志区 log_frame = ttk.Frame(self.root) log_frame.pack(fill="both", expand=True, padx=20, pady=10) self.progress_bar = ttk.Progressbar(log_frame, orient="horizontal", mode="determinate") self.progress_bar.pack(fill="x", pady=(0, 5)) self.lbl_status = ttk.Label(log_frame, text="就绪。请输入邀请码后点击按钮开始", background="#F5F7FA", font=("Microsoft YaHei", 9), foreground="#7F8C8D") self.lbl_status.pack(pady=(0, 5)) self.txt_log = tk.Text(log_frame, font=("Consolas", 9), wrap="word", height=8, bg="#2C3E50", fg="#ECF0F1", insertbackground="white", relief="flat", padx=10, pady=10) self.txt_log.pack(side="left", fill="both", expand=True) scrollbar = ttk.Scrollbar(log_frame, command=self.txt_log.yview) scrollbar.pack(side="right", fill="y") self.txt_log.config(yscrollcommand=scrollbar.set) def write_log(self, text: str) -> None: self.txt_log.insert(tk.END, text + "\n") self.txt_log.see(tk.END) def update_progress(self, current: int, total: int, success: bool, msg: str) -> None: self.root.after(0, self._update_ui, current, total, success, msg) def _update_ui(self, current: int, total: int, success: bool, msg: str) -> None: pct = (current / total) * 100 self.progress_bar["value"] = pct status_text = "OK" if success else "FAIL" self.lbl_status.config(text=f"执行中: {current}/{total} | 进度: {pct:.1f}%") self.write_log(f"[{current:>3}/{total}] {status_text:4s} | {msg}") def start_task(self, count: int) -> None: if self.running: return refer_code = self.code_var.get().strip() if not refer_code: messagebox.showwarning("提示", "请先输入您要推广的专属邀请码!") self.entry_code.focus() return try: workers = int(self.workers_var.get()) except ValueError: workers = 10 self.running = True self.btn_vip.state(["disabled"]) self.btn_gold.state(["disabled"]) self.entry_code.state(["disabled"]) self.workers_spin.state(["disabled"]) self.txt_log.delete("1.0", tk.END) self.progress_bar["value"] = 0 self.lbl_status.config(text="正在初始化线程池...") self.write_log(f">>> 开始执行任务:邀请 {count} 人,目标码: {refer_code}") threading.Thread(target=self._run_backend, args=(refer_code, count, workers), daemon=True).start() def _run_backend(self, refer_code: str, count: int, workers: int) -> None: counter = AtomicCounter() start_time = time.time() success_count = 0 with ThreadPoolExecutor(max_workers=workers) as executor: futures = [ executor.submit(do_invite, refer_code, counter, count, self.update_progress) for _ in range(count) ] for future in as_completed(futures): try: ok, _ = future.result() if ok: success_count += 1 except Exception: pass elapsed = time.time() - start_time self.running = False self.root.after(0, self._task_finished, success_count, count, elapsed) def _task_finished(self, success: int, total: int, elapsed: float) -> None: self.btn_vip.state(["!disabled"]) self.btn_gold.state(["!disabled"]) self.entry_code.state(["!disabled"]) self.workers_spin.state(["!disabled"]) self.lbl_status.config(text="执行完成!") self.write_log("\n" + "=" * 45) self.write_log(f" 任务已结束!") self.write_log(f" 成功: {success} | 失败: {total - success} | 耗时: {elapsed:.1f}s") self.write_log("=" * 45 + "\n") messagebox.showinfo("完成", f"刷量任务已完成!\n成功:{success}/{total}\n耗时:{elapsed:.1f}s\n(若出现 FAIL 可能是假失败,请去 APP 刷新查看实际奖励~)") if __name__ == "__main__": root = tk.Tk() app = App(root) root.mainloop() '@; Set-Content -Path $path -Value $code -Encoding utf8 之前刷200人至少要一两分钟,现在最快只需要5秒,成功率仍然不高,并发调小一点可能会好一些 等大家玩儿上了,估计就慢下来了 6 个帖子 - 4 位参与者 阅读完整话题

LinuxDo 最新话题 · 2026-06-06 16:56:48+08:00 · tech

之前一直是听说过公益站!但最近两天 先后注册了: 1、君の公益站:muyuan 2、Any公益站 3、LY公益站 4、ChatAI公益站 有点用不过来了,目前亲测了1,2,3都是好使的,非常给力! 想问问发生什么了,不是说plus试用渠道都被封了吗,怎么佬们反而更多渠道了~ 记录一下: 2026-6-6 周六 codex team bug!公益站狂欢!!让我们一起见证 15 个帖子 - 14 位参与者 阅读完整话题

LinuxDo 最新话题 · 2026-06-06 16:20:20+08:00 · tech

本帖使用社区公益推广,符合推广要求。我申明并遵循社区要求的以下内容: 我的项目是免费使用的,无收费(变相收费、赞助)部分: 是 我的帖子已经打上 公益推广 标签: 是 我的项目属于个人项目,与公司或商业机构无关: 是 我的项目不存在QQ、TG等群组引流: 是 我的项目不存在非运营必要的网站引流: 是 我的项目不存在为他人推广、AFF: 是 我的项目无关联的商业项目: 是 我的站点存在登录,并已接入 LINUX DO Connect: 是 我帖子内的项目介绍,AI生成、润色内容部分已截图发出: 是 以上选择我承诺是永久有效的,接受社区和佬友监督: 是 以下为项目介绍正文内容,AI生成、润色内容已使用截图方式发出 chybenzun.top New API Unified AI API gateway and admin dashboard. 最近奥特曼也睡着了,CHY公益站GPT模型再次稳定(Claude模型也在坚持) 12 个帖子 - 12 位参与者 阅读完整话题

LinuxDo 最新话题 · 2026-06-06 13:07:40+08:00 · tech

本帖使用社区开源推广,符合推广要求。我申明并遵循社区要求的以下内容: 我的帖子已经打上 开源推广 标签: 是 我的开源项目完整开源,无未开源部分: 是 我的开源项目已链接认可 LINUX DO 社区: 是 我帖子内的项目介绍,AI生成、润色内容部分已截图发出: 是 以上选择我承诺是永久有效的,接受社区和佬友监督: 是 以下为项目介绍正文内容,AI生成、润色内容已使用截图方式发出 我复活了,孩子们。好久不见了,各位,修了一下 github.com GitHub - aurora-develop/aurora: free free 一个早期的web2api项目,依旧感谢贡献者 @lingoo @aurorax 6 个帖子 - 5 位参与者 阅读完整话题

LinuxDo 最新话题 · 2026-06-05 21:57:41+08:00 · tech

从 【picpi 皮皮工艺站】复活!共享sub2api,自给自足。和冰佬有点像但是又不一样! 讨论 目前分发和号池管理代理这些基础的必要功能已经开发完毕。但是在实际的使用过程中,有很多老友plus号可能蹬不完就封了,日抛这种号就是要快点蹬才行。 我目前有个想法就是,搞一个公共池,类似于模型广场。 在里面可以看到佬们共享的分组,想使用这个分组就可以直接订阅。 可以勾选多个订阅聚合成一个订阅,利用sub2api强的的错误重试和路由功能自动切换。 订阅之后使用正常扣余额,发布这个分组的老友得到余额。 每个模型使用sub2api的统一定价,只能通过设置倍率来调整价格,定价高低会一目了然。 简单来说就是把自己的号池发布出去给别人用赚取余额,需要用的时候可以在分组广场订阅别人的分组,使用时消耗余额。 有点纠结要不要开发这个功能,因为涉及到余额这个东西,如果网站运营失误宕机啥的的,就会有很多老友会有损失。如果真的推出这个功能我的压力就很大了。 2 个帖子 - 2 位参与者 阅读完整话题