From 8f190dc81ee95965fdb597e18ebf96a075b2f816 Mon Sep 17 00:00:00 2001 From: smallfawn <860562056@QQ.COM> Date: Sun, 5 Apr 2026 14:31:51 +0800 Subject: [PATCH] feat(new mxbc): new mxbc --- daily/mtf.js | 138 +++++++++ mtf.js | 844 --------------------------------------------------- mxbc.js | 435 +++++++++++++------------- 3 files changed, 353 insertions(+), 1064 deletions(-) create mode 100644 daily/mtf.js delete mode 100644 mtf.js diff --git a/daily/mtf.js b/daily/mtf.js new file mode 100644 index 0000000..e023227 --- /dev/null +++ b/daily/mtf.js @@ -0,0 +1,138 @@ +/* +------------------------------------------ +@Author: sm +@Date: 2024.06.07 19:15 +@Description: 摩托范APP签到和抽奖 +cron: 30 10 * * * +------------------------------------------ +#Notice: +变量名 :mtf +抓域名 api.58moto.com 下请求中 token和uid 的值填入变量 用#连接 多账户&或换行 +⚠️【免责声明】 +------------------------------------------ +1、此脚本仅用于学习研究,不保证其合法性、准确性、有效性,请根据情况自行判断,本人对此不承担任何保证责任。 +2、由于此脚本仅用于学习研究,您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除,若违反规定引起任何事件本人对此均不负责。 +3、请勿将此脚本用于任何商业或非法目的,若违反规定请自行对此负责。 +4、此脚本涉及应用与本人无关,本人对因此引起的任何隐私泄漏或其他后果不承担任何责任。 +5、本人对任何脚本引发的问题概不负责,包括但不限于由脚本错误引起的任何损失和损害。 +6、如果任何单位或个人认为此脚本可能涉嫌侵犯其权利,应及时通知并提供身份证明,所有权证明,我们将在收到认证文件确认后删除此脚本。 +7、所有直接或间接使用、查看此脚本的人均应该仔细阅读此声明。本人保留随时更改或补充此声明的权利。一旦您使用或复制了此脚本,即视为您已接受此免责声明。 +*/ + +const { Env } = require("../tools/env") +const $ = new Env("摩托范"); +let ckName = `mtf`; +const strSplitor = "#"; +const axios = require("axios"); +const defaultUserAgent = "Mozilla/5.0 (iPhone; CPU iPhone OS 16_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.31(0x18001e31) NetType/WIFI Language/zh_CN miniProgram" + + +class Task { + constructor(env) { + this.index = $.userIdx++ + this.user = env.split(strSplitor); + this.token = this.user[0]; + this.uid = this.user[1]; + + } + + async run() { + await this.userInfo() + await this.signIn() + await this.drwa() + } + async userInfo() { + let options = { + method: 'POST', + url: `https://api.58moto.com/user/center/info/principal`, + headers: { + "token": this.token, + "content-type": "application/x-www-form-urlencoded" + }, + data: "uid=" + this.uid + } + let { data: result } = await axios.request(options); + if (result?.code == 0) { + $.log(`查询成功:当前手机号${result.data.mobile} \n 用户昵称为${result.data.username} 🎉`); + } else { + $.log(`查询: 失败 ❌ 了呢,原因未知!`); + console.log(result); + } + } + async signIn() { + let options = { + method: 'POST', + url: `https://api.58moto.com/coins/task/dailyCheckIn`, + headers: { + "token": this.token, + "content-type": "application/x-www-form-urlencoded" + }, + data: "uid=" + this.uid + "&weekDate=" + $.time('yyyyMMdd') + } + let { data: result } = await axios.request(options); + + if (result?.code == 0) { + $.log(`签到成功:${result.data.contentDesc} 🎉`); + } else if (result?.code == 300101) { + $.log(`签到失败:${result.msg},请勿重复签到`); + } else { + $.log(`签到: 失败 ❌ 了呢,原因未知!`); + console.log(result); + } + + + + + } + async drwa() { + let options = { + method: 'POST', + url: `https://jsapi.58moto.com/coins/turntable/activity/draw`, + headers: { + "content-type": "application/x-www-form-urlencoded" + }, + data: `token=${this.token}&uid=${this.uid}&autherid=${this.uid}&platform=2&version=3.66.80&deviceId=53B5DA97-C72D-4C19-A219-70D8A9A31290&bundleId=com.jdd.motorfans&activityId=24` + } + let { data: result } = await axios.request(options); + if (result?.code == 0) { + $.log(`抽奖成功:${result.data.awardName} 🎉`); + } else { + $.log(`抽奖: 失败 ❌ 了呢,原因未知!`); + console.log(result); + } + + + + + } + + + //做任务需要wtoken逆向 不想写 + + + + +} + +!(async () => { + await getNotice() + $.checkEnv(ckName); + + for (let user of $.userList) { + await new Task(user).run(); + } +})() + .catch((e) => console.log(e)) + .finally(() => $.done()); + +async function getNotice() { + let options = { + url: `https://ghproxy.net/https://raw.githubusercontent.com/smallfawn/Note/refs/heads/main/Notice.json`, + headers: { + "User-Agent": defaultUserAgent, + } + } + let { data: res } = await axios.request(options); + $.log(res) + return res +} \ No newline at end of file diff --git a/mtf.js b/mtf.js deleted file mode 100644 index fbe119e..0000000 --- a/mtf.js +++ /dev/null @@ -1,844 +0,0 @@ -/** - * - * 项目昵称:摩托范 - * - * cron 0 0,7 * * * mtf.js - * - * 9-5 签到兑换实物 - * - * ========= 青龙--配置文件 ========= - * 变量格式: export mtf_data='' ,多账号用 换行 或 @ 分割 - * 抓域名 api.58moto.com 下请求中 token和uid 的值填入变量 用&连接 - */ - - const { log } = require("console"); - - const $ = new Env("摩托范"); - const notify = $.isNode() ? require("./sendNotify") : ""; - const Notify = 1 - const debug = 0 - //--------------------------------------------------------------------------------------------------------- - let ckStr = ($.isNode() ? process.env.mtf_data : $.getdata('mtf_data')) || ''; - let msg, ck; - let ck_status = true; - let host = 'api.58moto.com'; - let hostname = 'https://' + host; - //let UA = $.isNode() ? (require('./user_agents.js').user_agent) : "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.0.0 Safari/537.36"; - //--------------------------------------------------------------------------------------------------------- - let Version = `V 0.0.1` - let Change = '每天签到 ,兑换实物' - let thank = `\n感谢 群友 的投稿\n` - let githubproxy = "https://ghproxy.com/" - //--------------------------------------------------------------------------------------------------------- - - async function tips(ckArr) { - DoubleLog(`当前脚本版本${Version}\n📌,如果脚本版本不一致请及时更新`); - // DoubleLog(`${thank}`); - //await wyy(); //网易云API 查询 失效则不能运行 - DoubleLog(`\n========== 共找到 ${ckArr.length} 个账号 ==========`); - debugLog(`【debug】 这是你的账号数组:\n ${ckArr}`); - } - - - !(async () => { - let ckArr = await checkEnv(ckStr, "mtf_data"); - console.log("开始获取公告") - //await ScriptText("demo"); //远程获取公告 - await tips(ckArr); - for (let index = 0; index < ckArr.length; index++) { - let num = index + 1; - DoubleLog(`\n-------- 开始【第 ${num} 个账号】--------`); - ck = ckArr[index].split("&"); //单账号多变量分割符,如果一个账号需要user和token两个变量,那么则输入user1&token1@user2&token2... - debugLog(`【debug】 这是你第 ${num} 账号信息:\n ${ck}`); //单账号多变量 调用格式 ck[0] 和ck[1],ck[0]指的就是user1 ck[1]就是token1 - await start(); //单独拿出来一个账号执行 strat函数任务 - } - await SendMsg(msg); - - })() - .catch((e) => $.logErr(e)) - .finally(() => $.done()); - - - async function start() { - - console.log("\n开始 用户信息查询"); - await userinfo(); - await $.wait(3 * 1000); - //weekdate = local_year() + local_month_two(); +local_day_two(); 年份月份日期 - console.log("\n开始 签到"); - await signin(); - await $.wait(3 * 1000); - - console.log("\n开始 查询日常任务"); - await taskList(); - await $.wait(3 * 1000); - //以上 三行代码可以复制 只需要改动 函数名和输出 - - - - } - - - /** - * 用户信息 httpGet或者httpPost 看你的请求头 - */ - async function userinfo() { - try { - let url = { - url: `${hostname}/user/center/info/principal`, - headers: { - "Host": host, - "token": ck[0], - "content-type": "application/x-www-form-urlencoded" - }, - body: "uid=" + ck[1] - - }; - let result = await httpPost(url, `用户信息查询`); - - console.log(result); - if (result?.code == 0) { - DoubleLog(`查询成功:当前手机号${result.data.mobile} \n 用户昵称为${result.data.username} 🎉`); - await wait(3); - } else { - DoubleLog(`查询: 失败 ❌ 了呢,原因未知!`); - console.log(result); - } - } catch (error) { - console.log(error); - } - -} - - - - /** - * 签到 httpGet或者httpPost 看你的请求头 - */ - async function signin() { - try { - let url = { - url: `${hostname}/coins/task/dailyCheckIn`, - headers: { - "Host": host, - "token": ck[0], - "content-type": "application/x-www-form-urlencoded" - }, - body: "uid=" + ck[1] + "&weekDate=" + local_year() + 0 +parseFloat(local_month()+1) + local_day_two() - - }; - let result = await httpPost(url, `签到`); - - console.log(result); - if (result?.code == 0) { - DoubleLog(`签到成功:${result.data.contentDesc} 🎉`); - await wait(3); - } else if (result?.code == 300101) { - DoubleLog(`签到失败:${result.msg},请勿重复签到`); - } else { - DoubleLog(`签到: 失败 ❌ 了呢,原因未知!`); - console.log(result); - } - } catch (error) { - console.log(error); - } - - } - - /** - * 查询日常任务 httpGet或者httpPost 看你的请求头 - */ - async function taskList() { - try { - let url = { - url: `${hostname}/coins/task/taskList`, - headers: { - "Host": host, - "token": ck[0], - "version": "3.52.40" - }, - - }; - let result = await httpGet(url, `日常任务查询`); - - console.log(result); - if (result?.code == 0) { - for (var invite = 0; invite < result.data.length; invite++) { - DoubleLog(`查询成功:第` + parseFloat(invite+1) + `个任务为${result.data[invite].taskName} \n 任务ID为${result.data[invite].taskId} 🎉`); - await wait(2); - } - } else { - DoubleLog(`查询: 失败 ❌ 了呢,原因未知!`); - console.log(result); - } - } catch (error) { - console.log(error); - } - -} - - - - /** - * 积分 httpPost //参考上面的即可 这个函数也可以复制 改下相应的就可以 - */ - async function jifen() { - try { - let url = { - url: `${hostname}/xxx/xxx`, - headers: { - "Host": host, - "User-Agent": "xxx", - "Cookie": ck[0], - } - }; - let result = await httpGet(url, `查询积分`); - - console.log(result); - if (result?.code == 200) { - DoubleLog(`查询积分:${result?.chnDesc} 🎉,当前积分:${result?.recordList.pointValueAfterChange} `); - await wait(3); - } else { - DoubleLog(`查询积分: 失败 ❌ 了呢,原因未知!`); - console.log(result); - } - } catch (error) { - console.log(error); - } - -} - - - - - - - - - //---------------------这里往下不要动+++--------------------------------- - - - // #region ******************************************************** 固定代码 ******************************************************** - /** - * 变量检查 - */ - async function checkEnv(ck, Variables) { - return new Promise((resolve) => { - let ckArr = [] - if (ck) { - if (ck.indexOf("@") !== -1) { - - ck.split("@").forEach((item) => { - ckArr.push(item); - }); - } else if (ck.indexOf("\n") !== -1) { - - ck.split("\n").forEach((item) => { - ckArr.push(item); - }); - } else { - ckArr.push(ck); - } - resolve(ckArr) - } else { - console.log(` ${$.neme}:未填写变量 ${Variables} ,请仔细阅读脚本说明!`) - } - } - ) - } - -//----------------------------------获取公告和脚本版本 - - async function ScriptText(name) { - try { - let url = { - url: githubproxy + `https://raw.githubusercontent.com/zhaoshicong/QLScriptPublic/main/text.json`, - }; - let result = await httpGet(url, `输出`); - //console.log(result); - if (result?.Status == "true") { - DoubleLog(`公告:${result.Notice} 🎉`); - DoubleLog(`远程仓库脚本最新版本为:${result.Script[name].version} \n 脚本更新内容为${result.Script[name].text}`) - await wait(1); - } else { - DoubleLog(`获取公告及其版本: 失败 ❌ 了呢,原因未知!`); - //console.log(result); - } - } catch (error) { - console.log(error); - } - - } - - - - - /** - * 发送消息 - */ - async function SendMsg(message) { - if (!message) return; - if (Notify > 0) { - if ($.isNode()) { - var notify = require("./sendNotify"); - await notify.sendNotify($.name, message); - } else { - // $.msg(message); - $.msg($.name, '', message) - } - } else { - console.log(message); - } - } - - /** - * 双平台log输出 - */ - function DoubleLog(data) { - if ($.isNode()) { - if (data) { - console.log(` ${data}`); - msg += `\n ${data}`; - } - } else { - console.log(` ${data}`); - msg += `\n ${data}`; - } - - } - - /** - * 随机 数字 + 大写字母 生成 - */ - function randomszdx(e) { - e = e || 32; - var t = "QWERTYUIOPASDFGHJKLZXCVBNM1234567890", - a = t.length, - n = ""; - - for (i = 0; i < e; i++) n += t.charAt(Math.floor(Math.random() * a)); - return n; - } - - - /** - * 随机 数字 + 小写字母 生成 - */ - function randomszxx(e) { - e = e || 32; - var t = "qwertyuioplkjhgfdsazxcvbnm1234567890", - a = t.length, - n = ""; - - for (i = 0; i < e; i++) n += t.charAt(Math.floor(Math.random() * a)); - return n; - } - - - - - /** - * 随机整数生成 - */ - function randomInt(min, max) { - return Math.round(Math.random() * (max - min) + min); - } - - - /** - * 时间戳 13位 - */ - function ts13() { - return Math.round(new Date().getTime()).toString(); - } - - /** - * 时间戳 10位 - */ - function ts10() { - return Math.round(new Date().getTime() / 1000).toString(); - } - - /** - * 获取当前小时数 - */ - function local_hours() { - let myDate = new Date(); - let h = myDate.getHours(); - return h; - } - - /** - * 获取当前分钟数 - */ - function local_minutes() { - let myDate = new Date(); - let m = myDate.getMinutes(); - return m; - } - - - /** - * 获取当前年份 2022 - */ - function local_year() { - let myDate = new Date(); - y = myDate.getFullYear(); - return y; - } - - /** - * 获取当前月份(数字) 5月 - */ - function local_month() { - let myDate = new Date(); - let m = myDate.getMonth(); - return m; - } - - - /** - * 获取当前月份(数字) 05月 补零 - */ - function local_month_two() { - let myDate = new Date(); - let m = myDate.getMonth(); - if (m.toString().length == 1) { - m = `0${m}` - } - return m; - } - - /** - * 获取当前天数(数字) 5日 - */ - function local_day() { - let myDate = new Date(); - let d = myDate.getDate(); - return d; - } - - - /** - * 获取当前天数 05日 补零 - */ - function local_day_two() { - let myDate = new Date(); - let d = myDate.getDate(); - if (d.toString().length == 1) { - d = `0${d}` - } - return d; - } - - - - /** - * 等待 X 秒 - */ - function wait(n) { - return new Promise(function (resolve) { - setTimeout(resolve, n * 1000); - }); - } - - - /** - * 每日网抑云 - */ - function wyy() { - return new Promise((resolve) => { - let url = { - url: `http://ovooa.com/API/wyrp/api.php`, - } - $.get(url, async (err, resp, data) => { - try { - data = JSON.parse(data); - // console.log(data); - console.log(`网抑云时间: ${data.data.Content} by--${data.data.Music}`) - msg = `[网抑云时间]: ${data.data.Content} by--${data.data.Music}` - // DoubleLog(`[网抑云时间]: ${data.data.Content} by--${data.data.Music}`); - } catch (e) { - $.logErr(e, resp); - } finally { - resolve() - } - }, timeout = 3) - }) - } - - /** - * get请求 - */ - async function httpGet(getUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = getUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.get( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - msg = `\n ${tip} 失败了!请稍后尝试!!` - } finally { - resolve(); - } - }, - timeout - ); - }); - } - - /** - * post请求 - */ - async function httpPost(postUrlObject, tip, timeout = 3) { - return new Promise((resolve) => { - let url = postUrlObject; - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 url ===============`); - console.log(url); - } - - $.post( - url, - async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回data==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (result == undefined) { - return; - } else { - resolve(result); - } - - } catch (e) { - console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - msg = `\n ${tip} 失败了!请稍后尝试!!` - } finally { - resolve(); - } - }, - timeout - ); - }); - } - - /** - * 网络请求 (get, post等) - */ - async function httpRequest(postOptionsObject, tip, timeout = 3) { - return new Promise((resolve) => { - - let Options = postOptionsObject; - let request = require('request'); - if (!tip) { - let tmp = arguments.callee.toString(); - let re = /function\s*(\w*)/i; - let matches = re.exec(tmp); - tip = matches[1]; - } - if (debug) { - console.log(`\n 【debug】=============== 这是 ${tip} 请求 信息 ===============`); - console.log(Options); - } - - request(Options, async (err, resp, data) => { - try { - if (debug) { - console.log(`\n\n 【debug】===============这是 ${tip} 返回数据==============`); - console.log(data); - console.log(`\n 【debug】=============这是 ${tip} json解析后数据============`); - console.log(JSON.parse(data)); - } - let result = JSON.parse(data); - if (!result) return; - resolve(result); - } catch (e) { - console.log(err, resp); - console.log(`\n ${tip} 失败了!请稍后尝试!!`); - msg = `\n ${tip} 失败了!请稍后尝试!!` - } finally { - resolve(); - } - }), timeout - - }); - } - - - /** - * debug调试 - */ - function debugLog(...args) { - if (debug) { - console.log(...args); - } - } - - - - // /** - // * 单名字 Env - // */ - // function Env() { - // return new class { - // isNode() { - // return "undefined" != typeof module && !!module.exports - // } - // }() - // } - - - // md5 - function MD5Encrypt(a) { function b(a, b) { return a << b | a >>> 32 - b } function c(a, b) { var c, d, e, f, g; return e = 2147483648 & a, f = 2147483648 & b, c = 1073741824 & a, d = 1073741824 & b, g = (1073741823 & a) + (1073741823 & b), c & d ? 2147483648 ^ g ^ e ^ f : c | d ? 1073741824 & g ? 3221225472 ^ g ^ e ^ f : 1073741824 ^ g ^ e ^ f : g ^ e ^ f } function d(a, b, c) { return a & b | ~a & c } function e(a, b, c) { return a & c | b & ~c } function f(a, b, c) { return a ^ b ^ c } function g(a, b, c) { return b ^ (a | ~c) } function h(a, e, f, g, h, i, j) { return a = c(a, c(c(d(e, f, g), h), j)), c(b(a, i), e) } function i(a, d, f, g, h, i, j) { return a = c(a, c(c(e(d, f, g), h), j)), c(b(a, i), d) } function j(a, d, e, g, h, i, j) { return a = c(a, c(c(f(d, e, g), h), j)), c(b(a, i), d) } function k(a, d, e, f, h, i, j) { return a = c(a, c(c(g(d, e, f), h), j)), c(b(a, i), d) } function l(a) { for (var b, c = a.length, d = c + 8, e = (d - d % 64) / 64, f = 16 * (e + 1), g = new Array(f - 1), h = 0, i = 0; c > i;)b = (i - i % 4) / 4, h = i % 4 * 8, g[b] = g[b] | a.charCodeAt(i) << h, i++; return b = (i - i % 4) / 4, h = i % 4 * 8, g[b] = g[b] | 128 << h, g[f - 2] = c << 3, g[f - 1] = c >>> 29, g } function m(a) { var b, c, d = "", e = ""; for (c = 0; 3 >= c; c++)b = a >>> 8 * c & 255, e = "0" + b.toString(16), d += e.substr(e.length - 2, 2); return d } function n(a) { a = a.replace(/\r\n/g, "\n"); for (var b = "", c = 0; c < a.length; c++) { var d = a.charCodeAt(c); 128 > d ? b += String.fromCharCode(d) : d > 127 && 2048 > d ? (b += String.fromCharCode(d >> 6 | 192), b += String.fromCharCode(63 & d | 128)) : (b += String.fromCharCode(d >> 12 | 224), b += String.fromCharCode(d >> 6 & 63 | 128), b += String.fromCharCode(63 & d | 128)) } return b } var o, p, q, r, s, t, u, v, w, x = [], y = 7, z = 12, A = 17, B = 22, C = 5, D = 9, E = 14, F = 20, G = 4, H = 11, I = 16, J = 23, K = 6, L = 10, M = 15, N = 21; for (a = n(a), x = l(a), t = 1732584193, u = 4023233417, v = 2562383102, w = 271733878, o = 0; o < x.length; o += 16)p = t, q = u, r = v, s = w, t = h(t, u, v, w, x[o + 0], y, 3614090360), w = h(w, t, u, v, x[o + 1], z, 3905402710), v = h(v, w, t, u, x[o + 2], A, 606105819), u = h(u, v, w, t, x[o + 3], B, 3250441966), t = h(t, u, v, w, x[o + 4], y, 4118548399), w = h(w, t, u, v, x[o + 5], z, 1200080426), v = h(v, w, t, u, x[o + 6], A, 2821735955), u = h(u, v, w, t, x[o + 7], B, 4249261313), t = h(t, u, v, w, x[o + 8], y, 1770035416), w = h(w, t, u, v, x[o + 9], z, 2336552879), v = h(v, w, t, u, x[o + 10], A, 4294925233), u = h(u, v, w, t, x[o + 11], B, 2304563134), t = h(t, u, v, w, x[o + 12], y, 1804603682), w = h(w, t, u, v, x[o + 13], z, 4254626195), v = h(v, w, t, u, x[o + 14], A, 2792965006), u = h(u, v, w, t, x[o + 15], B, 1236535329), t = i(t, u, v, w, x[o + 1], C, 4129170786), w = i(w, t, u, v, x[o + 6], D, 3225465664), v = i(v, w, t, u, x[o + 11], E, 643717713), u = i(u, v, w, t, x[o + 0], F, 3921069994), t = i(t, u, v, w, x[o + 5], C, 3593408605), w = i(w, t, u, v, x[o + 10], D, 38016083), v = i(v, w, t, u, x[o + 15], E, 3634488961), u = i(u, v, w, t, x[o + 4], F, 3889429448), t = i(t, u, v, w, x[o + 9], C, 568446438), w = i(w, t, u, v, x[o + 14], D, 3275163606), v = i(v, w, t, u, x[o + 3], E, 4107603335), u = i(u, v, w, t, x[o + 8], F, 1163531501), t = i(t, u, v, w, x[o + 13], C, 2850285829), w = i(w, t, u, v, x[o + 2], D, 4243563512), v = i(v, w, t, u, x[o + 7], E, 1735328473), u = i(u, v, w, t, x[o + 12], F, 2368359562), t = j(t, u, v, w, x[o + 5], G, 4294588738), w = j(w, t, u, v, x[o + 8], H, 2272392833), v = j(v, w, t, u, x[o + 11], I, 1839030562), u = j(u, v, w, t, x[o + 14], J, 4259657740), t = j(t, u, v, w, x[o + 1], G, 2763975236), w = j(w, t, u, v, x[o + 4], H, 1272893353), v = j(v, w, t, u, x[o + 7], I, 4139469664), u = j(u, v, w, t, x[o + 10], J, 3200236656), t = j(t, u, v, w, x[o + 13], G, 681279174), w = j(w, t, u, v, x[o + 0], H, 3936430074), v = j(v, w, t, u, x[o + 3], I, 3572445317), u = j(u, v, w, t, x[o + 6], J, 76029189), t = j(t, u, v, w, x[o + 9], G, 3654602809), w = j(w, t, u, v, x[o + 12], H, 3873151461), v = j(v, w, t, u, x[o + 15], I, 530742520), u = j(u, v, w, t, x[o + 2], J, 3299628645), t = k(t, u, v, w, x[o + 0], K, 4096336452), w = k(w, t, u, v, x[o + 7], L, 1126891415), v = k(v, w, t, u, x[o + 14], M, 2878612391), u = k(u, v, w, t, x[o + 5], N, 4237533241), t = k(t, u, v, w, x[o + 12], K, 1700485571), w = k(w, t, u, v, x[o + 3], L, 2399980690), v = k(v, w, t, u, x[o + 10], M, 4293915773), u = k(u, v, w, t, x[o + 1], N, 2240044497), t = k(t, u, v, w, x[o + 8], K, 1873313359), w = k(w, t, u, v, x[o + 15], L, 4264355552), v = k(v, w, t, u, x[o + 6], M, 2734768916), u = k(u, v, w, t, x[o + 13], N, 1309151649), t = k(t, u, v, w, x[o + 4], K, 4149444226), w = k(w, t, u, v, x[o + 11], L, 3174756917), v = k(v, w, t, u, x[o + 2], M, 718787259), u = k(u, v, w, t, x[o + 9], N, 3951481745), t = c(t, p), u = c(u, q), v = c(v, r), w = c(w, s); var O = m(t) + m(u) + m(v) + m(w); return O.toLowerCase() } - - - - - /* SHA256 logical functions */ - function rotateRight(n, x) { - return ((x >>> n) | (x << (32 - n))); - } - function choice(x, y, z) { - return ((x & y) ^ (~x & z)); - } - function majority(x, y, z) { - return ((x & y) ^ (x & z) ^ (y & z)); - } - function sha256_Sigma0(x) { - return (rotateRight(2, x) ^ rotateRight(13, x) ^ rotateRight(22, x)); - } - function sha256_Sigma1(x) { - return (rotateRight(6, x) ^ rotateRight(11, x) ^ rotateRight(25, x)); - } - function sha256_sigma0(x) { - return (rotateRight(7, x) ^ rotateRight(18, x) ^ (x >>> 3)); - } - function sha256_sigma1(x) { - return (rotateRight(17, x) ^ rotateRight(19, x) ^ (x >>> 10)); - } - function sha256_expand(W, j) { - return (W[j & 0x0f] += sha256_sigma1(W[(j + 14) & 0x0f]) + W[(j + 9) & 0x0f] + - sha256_sigma0(W[(j + 1) & 0x0f])); - } - - /* Hash constant words K: */ - var K256 = new Array( - 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, - 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, - 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, - 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, - 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, - 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, - 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, - 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, - 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, - 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, - 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, - 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070, - 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, - 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, - 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, - 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2 - ); - - /* global arrays */ - var ihash, count, buffer; - var sha256_hex_digits = "0123456789abcdef"; - - /* Add 32-bit integers with 16-bit operations (bug in some JS-interpreters: - overflow) */ - function safe_add(x, y) { - var lsw = (x & 0xffff) + (y & 0xffff); - var msw = (x >> 16) + (y >> 16) + (lsw >> 16); - return (msw << 16) | (lsw & 0xffff); - } - - /* Initialise the SHA256 computation */ - function sha256_init() { - ihash = new Array(8); - count = new Array(2); - buffer = new Array(64); - count[0] = count[1] = 0; - ihash[0] = 0x6a09e667; - ihash[1] = 0xbb67ae85; - ihash[2] = 0x3c6ef372; - ihash[3] = 0xa54ff53a; - ihash[4] = 0x510e527f; - ihash[5] = 0x9b05688c; - ihash[6] = 0x1f83d9ab; - ihash[7] = 0x5be0cd19; - } - - /* Transform a 512-bit message block */ - function sha256_transform() { - var a, b, c, d, e, f, g, h, T1, T2; - var W = new Array(16); - - /* Initialize registers with the previous intermediate value */ - a = ihash[0]; - b = ihash[1]; - c = ihash[2]; - d = ihash[3]; - e = ihash[4]; - f = ihash[5]; - g = ihash[6]; - h = ihash[7]; - - /* make 32-bit words */ - for (var i = 0; i < 16; i++) - W[i] = ((buffer[(i << 2) + 3]) | (buffer[(i << 2) + 2] << 8) | (buffer[(i << 2) + 1] - << 16) | (buffer[i << 2] << 24)); - - for (var j = 0; j < 64; j++) { - T1 = h + sha256_Sigma1(e) + choice(e, f, g) + K256[j]; - if (j < 16) T1 += W[j]; - else T1 += sha256_expand(W, j); - T2 = sha256_Sigma0(a) + majority(a, b, c); - h = g; - g = f; - f = e; - e = safe_add(d, T1); - d = c; - c = b; - b = a; - a = safe_add(T1, T2); - } - - /* Compute the current intermediate hash value */ - ihash[0] += a; - ihash[1] += b; - ihash[2] += c; - ihash[3] += d; - ihash[4] += e; - ihash[5] += f; - ihash[6] += g; - ihash[7] += h; - } - - /* Read the next chunk of data and update the SHA256 computation */ - function sha256_update(data, inputLen) { - var i, index, curpos = 0; - /* Compute number of bytes mod 64 */ - index = ((count[0] >> 3) & 0x3f); - var remainder = (inputLen & 0x3f); - - /* Update number of bits */ - if ((count[0] += (inputLen << 3)) < (inputLen << 3)) count[1]++; - count[1] += (inputLen >> 29); - - /* Transform as many times as possible */ - for (i = 0; i + 63 < inputLen; i += 64) { - for (var j = index; j < 64; j++) - buffer[j] = data.charCodeAt(curpos++); - sha256_transform(); - index = 0; - } - - /* Buffer remaining input */ - for (var j = 0; j < remainder; j++) - buffer[j] = data.charCodeAt(curpos++); - } - - /* Finish the computation by operations such as padding */ - function sha256_final() { - var index = ((count[0] >> 3) & 0x3f); - buffer[index++] = 0x80; - if (index <= 56) { - for (var i = index; i < 56; i++) - buffer[i] = 0; - } else { - for (var i = index; i < 64; i++) - buffer[i] = 0; - sha256_transform(); - for (var i = 0; i < 56; i++) - buffer[i] = 0; - } - buffer[56] = (count[1] >>> 24) & 0xff; - buffer[57] = (count[1] >>> 16) & 0xff; - buffer[58] = (count[1] >>> 8) & 0xff; - buffer[59] = count[1] & 0xff; - buffer[60] = (count[0] >>> 24) & 0xff; - buffer[61] = (count[0] >>> 16) & 0xff; - buffer[62] = (count[0] >>> 8) & 0xff; - buffer[63] = count[0] & 0xff; - sha256_transform(); - } - - /* Split the internal hash values into an array of bytes */ - function sha256_encode_bytes() { - var j = 0; - var output = new Array(32); - for (var i = 0; i < 8; i++) { - output[j++] = ((ihash[i] >>> 24) & 0xff); - output[j++] = ((ihash[i] >>> 16) & 0xff); - output[j++] = ((ihash[i] >>> 8) & 0xff); - output[j++] = (ihash[i] & 0xff); - } - return output; - } - - /* Get the internal hash as a hex string */ - function sha256_encode_hex() { - var output = new String(); - for (var i = 0; i < 8; i++) { - for (var j = 28; j >= 0; j -= 4) - output += sha256_hex_digits.charAt((ihash[i] >>> j) & 0x0f); - } - return output; - } - - /* Main function: returns a hex string representing the SHA256 value of the - given data */ - function sha256_Encrypt(data) { - sha256_init(); - sha256_update(data, data.length); - sha256_final(); - return sha256_encode_hex(); - } - - - - // 完整 Env - function Env(t, e) { "undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0); class s { constructor(t) { this.env = t } send(t, e = "GET") { t = "string" == typeof t ? { url: t } : t; let s = this.get; return "POST" === e && (s = this.post), new Promise((e, i) => { s.call(this, t, (t, s, r) => { t ? i(t) : e(s) }) }) } get(t) { return this.send.call(this.env, t) } post(t) { return this.send.call(this.env, t, "POST") } } return new class { constructor(t, e) { this.name = t, this.http = new s(this), this.data = null, this.dataFile = "box.dat", this.logs = [], this.isMute = !1, this.isNeedRewrite = !1, this.logSeparator = "\n", this.startTime = (new Date).getTime(), Object.assign(this, e), this.log("", `🔔${this.name}, 开始!`) } isNode() { return "undefined" != typeof module && !!module.exports } isQuanX() { return "undefined" != typeof $task } isSurge() { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } isLoon() { return "undefined" != typeof $loon } toObj(t, e = null) { try { return JSON.parse(t) } catch { return e } } toStr(t, e = null) { try { return JSON.stringify(t) } catch { return e } } getjson(t, e) { let s = e; const i = this.getdata(t); if (i) try { s = JSON.parse(this.getdata(t)) } catch { } return s } setjson(t, e) { try { return this.setdata(JSON.stringify(t), e) } catch { return !1 } } getScript(t) { return new Promise(e => { this.get({ url: t }, (t, s, i) => e(i)) }) } runScript(t, e) { return new Promise(s => { let i = this.getdata("@chavy_boxjs_userCfgs.httpapi"); i = i ? i.replace(/\n/g, "").trim() : i; let r = this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout"); r = r ? 1 * r : 20, r = e && e.timeout ? e.timeout : r; const [o, h] = i.split("@"), n = { url: `http://${h}/v1/scripting/evaluate`, body: { script_text: t, mock_type: "cron", timeout: r }, headers: { "X-Key": o, Accept: "*/*" } }; this.post(n, (t, e, i) => s(i)) }).catch(t => this.logErr(t)) } loaddata() { if (!this.isNode()) return {}; { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e); if (!s && !i) return {}; { const i = s ? t : e; try { return JSON.parse(this.fs.readFileSync(i)) } catch (t) { return {} } } } } writedata() { if (this.isNode()) { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e), r = JSON.stringify(this.data); s ? this.fs.writeFileSync(t, r) : i ? this.fs.writeFileSync(e, r) : this.fs.writeFileSync(t, r) } } lodash_get(t, e, s) { const i = e.replace(/\[(\d+)\]/g, ".$1").split("."); let r = t; for (const t of i) if (r = Object(r)[t], void 0 === r) return s; return r } lodash_set(t, e, s) { return Object(t) !== t ? t : (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []), e.slice(0, -1).reduce((t, s, i) => Object(t[s]) === t[s] ? t[s] : t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}, t)[e[e.length - 1]] = s, t) } getdata(t) { let e = this.getval(t); if (/^@/.test(t)) { const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t), r = s ? this.getval(s) : ""; if (r) try { const t = JSON.parse(r); e = t ? this.lodash_get(t, i, "") : e } catch (t) { e = "" } } return e } setdata(t, e) { let s = !1; if (/^@/.test(e)) { const [, i, r] = /^@(.*?)\.(.*?)$/.exec(e), o = this.getval(i), h = i ? "null" === o ? null : o || "{}" : "{}"; try { const e = JSON.parse(h); this.lodash_set(e, r, t), s = this.setval(JSON.stringify(e), i) } catch (e) { const o = {}; this.lodash_set(o, r, t), s = this.setval(JSON.stringify(o), i) } } else s = this.setval(t, e); return s } getval(t) { return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null } setval(t, e) { return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null } initGotEnv(t) { this.got = this.got ? this.got : require("got"), this.cktough = this.cktough ? this.cktough : require("tough-cookie"), this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar, t && (t.headers = t.headers ? t.headers : {}, void 0 === t.headers.Cookie && void 0 === t.cookieJar && (t.cookieJar = this.ckjar)) } get(t, e = (() => { })) { t.headers && (delete t.headers["Content-Type"], delete t.headers["Content-Length"]), this.isSurge() || this.isLoon() ? (this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.get(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) })) : this.isQuanX() ? (this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t))) : this.isNode() && (this.initGotEnv(t), this.got(t).on("redirect", (t, e) => { try { if (t.headers["set-cookie"]) { const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString(); s && this.ckjar.setCookieSync(s, null), e.cookieJar = this.ckjar } } catch (t) { this.logErr(t) } }).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) })) } post(t, e = (() => { })) { if (t.body && t.headers && !t.headers["Content-Type"] && (t.headers["Content-Type"] = "application/x-www-form-urlencoded"), t.headers && delete t.headers["Content-Length"], this.isSurge() || this.isLoon()) this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.post(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) }); else if (this.isQuanX()) t.method = "POST", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t)); else if (this.isNode()) { this.initGotEnv(t); const { url: s, ...i } = t; this.got.post(s, i).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) }) } } time(t, e = null) { const s = e ? new Date(e) : new Date; let i = { "M+": s.getMonth() + 1, "d+": s.getDate(), "H+": s.getHours(), "m+": s.getMinutes(), "s+": s.getSeconds(), "q+": Math.floor((s.getMonth() + 3) / 3), S: s.getMilliseconds() }; /(y+)/.test(t) && (t = t.replace(RegExp.$1, (s.getFullYear() + "").substr(4 - RegExp.$1.length))); for (let e in i) new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? i[e] : ("00" + i[e]).substr(("" + i[e]).length))); return t } msg(e = t, s = "", i = "", r) { const o = t => { if (!t) return t; if ("string" == typeof t) return this.isLoon() ? t : this.isQuanX() ? { "open-url": t } : this.isSurge() ? { url: t } : void 0; if ("object" == typeof t) { if (this.isLoon()) { let e = t.openUrl || t.url || t["open-url"], s = t.mediaUrl || t["media-url"]; return { openUrl: e, mediaUrl: s } } if (this.isQuanX()) { let e = t["open-url"] || t.url || t.openUrl, s = t["media-url"] || t.mediaUrl; return { "open-url": e, "media-url": s } } if (this.isSurge()) { let e = t.url || t.openUrl || t["open-url"]; return { url: e } } } }; if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) { let t = ["", "==============📣系统通知📣=============="]; t.push(e), s && t.push(s), i && t.push(i), console.log(t.join("\n")), this.logs = this.logs.concat(t) } } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, e) { const s = !this.isSurge() && !this.isQuanX() && !this.isLoon(); s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t) } wait(t) { return new Promise(e => setTimeout(e, t)) } done(t = {}) { const e = (new Date).getTime(), s = (e - this.startTime) / 1e3; this.log("", `🔔${this.name}, 结束! 🕛 ${s} 秒`), this.log(), (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t) } }(t, e) } - - //#endregion - diff --git a/mxbc.js b/mxbc.js index c6493f4..d13143d 100644 --- a/mxbc.js +++ b/mxbc.js @@ -1,170 +1,227 @@ -/** - * 蜜雪冰城 - * cron 11 12 * * * mxbc.js - * 感谢大佬的代码 - * ========= 青龙--配置文件 =========== - * # 项目名称 - * export mxbc_data='token @ token' - * - * 多账号用 换行 或 @ 分割 - * 抓包 mxsa.mxbc.net/api , 找到 Access-Token 即可 - * ==================================== - * - */ - - +/* +------------------------------------------ +@Author: sm +@Date: 2024.06.07 19:15 +@Description: 蜜雪冰城APP/小程序 +cron: 30 8 * * * +------------------------------------------ +#Notice: +抓https://mxsa.mxbc.net 请求头Access-Token 多账号&或换行 +变量名:mxbc +⚠️【免责声明】 +------------------------------------------ +1、此脚本仅用于学习研究,不保证其合法性、准确性、有效性,请根据情况自行判断,本人对此不承担任何保证责任。 +2、由于此脚本仅用于学习研究,您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除,若违反规定引起任何事件本人对此均不负责。 +3、请勿将此脚本用于任何商业或非法目的,若违反规定请自行对此负责。 +4、此脚本涉及应用与本人无关,本人对因此引起的任何隐私泄漏或其他后果不承担任何责任。 +5、本人对任何脚本引发的问题概不负责,包括但不限于由脚本错误引起的任何损失和损害。 +6、如果任何单位或个人认为此脚本可能涉嫌侵犯其权利,应及时通知并提供身份证明,所有权证明,我们将在收到认证文件确认后删除此脚本。 +7、所有直接或间接使用、查看此脚本的人均应该仔细阅读此声明。本人保留随时更改或补充此声明的权利。一旦您使用或复制了此脚本,即视为您已接受此免责声明。 +*/ +const { Env } = require("./tools/env") const $ = new Env("蜜雪冰城"); -const ckName = "mxbc_data"; -//-------------------- 一般不动变量区域 ------------------------------------- -const Notify = 1; //0为关闭通知,1为打开通知,默认为1 -let debug = 1; //Debug调试 0关闭 1开启 -let envSplitor = ["@", "\n"]; //多账号分隔符 -let ck = msg = ''; //let ck,msg -let host, hostname; -let userCookie = ($.isNode() ? process.env[ckName] : $.getdata(ckName)) || ''; -let userList = []; -let userIdx = 0; -let userCount = 0; -//---------------------- 自定义变量区域 ----------------------------------- -//--------------------------------------------------------- +let ckName = `mxbc`; +const strSplitor = "#"; +const axios = require("axios"); +const defaultUserAgent = "Mozilla/5.0 (iPhone; CPU iPhone OS 16_5 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.31(0x18001e31) NetType/WIFI Language/zh_CN miniProgram" -async function start() { - //await getNotice() - console.log('\n================== 用户CK ==================\n'); - taskall = []; - for (let user of userList) { - taskall.push(await user.user_info()); - await $.wait(1000); //延迟 1秒 可充分利用 $.环境函数 +class Task { + constructor(env) { + this.index = $.userIdx++ + this.user = env.split(strSplitor); + this.ck = this.user[0]; + this.activityOrigin = "" + this.activityUrl = "" } - await Promise.all(taskall); - console.log('\n================== 每日签到 ==================\n'); - taskall = []; - for (let user of userList) { - if (user.ckStatus) { - taskall.push(await user.task_signin()); - await $.wait(1000); //延迟 1秒 可充分利用 $.环境函数 + + async run() { + + await this.user_info() + await this.getLoginUrl() + if (this.activityOrigin) { + await this.getActivityToken() + await this.activityIndex() } - } - await Promise.all(taskall); - - - -} - - -class UserInfo { - constructor(str) { - this.index = ++userIdx; - this.ck = str.split('&')[0]; //单账号多变量分隔符 - //let ck = str.split('&') - //this.data1 = ck[0] - this.ckStatus = true } + async user_info() { + let time = Date.now() try { let options = { - url: `https://mxsa.mxbc.net/api/v1/customer/info?appId=d82be6bbc1da11eb9dd000163e122ecb&t=${ts13()}&sign=${getSHA256withRSA('appId=d82be6bbc1da11eb9dd000163e122ecb&t=' + ts13())}`, + url: `https://mxsa.mxbc.net/api/v1/customer/info?appId=d82be6bbc1da11eb9dd000163e122ecb&t=${time}&sign=${this.getSHA256withRSA('appId=d82be6bbc1da11eb9dd000163e122ecb&t=' + time)}`, headers: { - 'app': 'mxbc', - 'appchannel': 'xiaomi', - 'appversion': '3.0.3', - 'Access-Token': this.ck, 'Host': 'mxsa.mxbc.net', - 'Connection': 'Keep-Alive', - //'Accept-Encoding': 'gzip', - 'User-Agent': 'okhttp/4.4.1' + 'Connection': 'keep-alive', + 'user-agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 MicroMessenger/7.0.4.501 NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF', + 'xweb_xhr': 1, + 'Access-Token': this.ck, + 'Content-Type': 'application/json', + 'Accept': '*/*', + 'Sec-Fetch-Site': 'cross-site', + 'Sec-Fetch-Mode': 'cors', + 'Sec-Fetch-Dest': 'empty', + 'Referer': 'https://servicewechat.com/wx7696c66d2245d107/59/page-frame.html', + 'Accept-Language': 'en-us,en', + 'Accept-Encoding': 'gzip, deflate', + } } - //console.log(options); - let result = await httpRequest(options); - //console.log(result); + let { data: result } = await axios.request(options); if (result.code == 0) { - DoubleLog(`账号[${this.index}] 用户CK有效: [${result.data.mobilePhone}] 雪王币剩余[${result.data.customerPoint}]`); + $.log(`账号[${this.index}] 用户CK有效: [${result.data.mobilePhone}] 雪王币剩余[${result.data.customerPoint}]`); this.ckStatus = true } else { - DoubleLog(`账号[${this.index}] 用户CK失效:,原因未知!`); + $.log(`账号[${this.index}] 用户CK失效:,原因未知!`); this.ckStatus = false console.log(result); } } catch (e) { - console.log(e); + + } + } + async getLoginUrl() { + try { + let timestamp = Date.now(); + const options = { + method: 'GET', + url: `https://mxsa.mxbc.net/api/v1/duiba/getLoginUrl`, + params: { + "appId": "d82be6bbc1da11eb9dd000163e122ecb", + "t": timestamp, + "sign": this.getSHA256withRSA('appId=d82be6bbc1da11eb9dd000163e122ecb&t=' + timestamp) + }, + headers: { + 'Host': 'mxsa.mxbc.net', + 'Connection': 'keep-alive', + 'user-agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 MicroMessenger/7.0.4.501 NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF', + 'xweb_xhr': 1, + 'Access-Token': '' + this.ck, + 'Content-Type': 'application/json', + 'Accept': '*/*', + 'Sec-Fetch-Site': 'cross-site', + 'Sec-Fetch-Mode': 'cors', + 'Sec-Fetch-Dest': 'empty', + 'Referer': 'https://servicewechat.com/wx7696c66d2245d107/59/page-frame.html', + 'Accept-Language': 'en-us,en', + 'Accept-Encoding': 'gzip, deflate', + + } + }; + + let { data: res } = await axios.request(options); + if (res?.code == 0) { + this.activityOrigin = new URL(res?.data.loginUrl).origin; + this.activityUrl = res?.data.loginUrl; + return res?.data.loginUrl; + } else { + $.log(`获取跳转Url失败!原因未知!${res.msg}`); + + } + + } catch (e) { + $.log(`❌获取跳转Url失败!原因为${e}`); + } + } + ObjectKeys2LowerCase(e) { return e = Object.fromEntries(Object.entries(e).map((([e, t]) => [e.toLowerCase(), t]))), new Proxy(e, { get: function (e, t, r) { return Reflect.get(e, t.toLowerCase(), r) }, set: function (e, t, r, n) { return Reflect.set(e, t.toLowerCase(), r, n) } }) } + + + //获取活动token + async getActivityToken() { + try { + const opts = { + method: "GET", + url: this.activityUrl, + maxRedirects: 0, + // 关键点 2: 默认 Axios 认为非 2xx 是错误,需定义 302 为合法状态 + validateStatus: function (status) { + return status >= 200 && status < 400; // 允许 302 (或 3xx) 进入 .then + }, + headers: {} + } + let res = await axios.request(opts); + + let headers = this.ObjectKeys2LowerCase(res?.headers); + //对青龙进行兼容 + let session = Array.isArray(headers['set-cookie']) ? [...new Set(headers['set-cookie'])].join("") : headers['set-cookie']; + + let [wdata4, w_ts, _ac, wdata3, dcustom] = session.match(/(wdata4|w_ts|_ac|wdata3|dcustom)=.+?;/g) + this.session = wdata4 + w_ts + _ac + wdata3 + dcustom; + $.log(`✅ 获取活动token成功!`) + + + } catch (e) { + + $.log(`⛔️ 获取活动token失败!${e}`); + } + } + async activityIndex() { + try { + const opts = { + url: this.activityOrigin + "/chome/index", + params: { + from: "login", + spm: "76177.1.1.1" + }, + headers: { + 'Cookie': this.session, + + 'User-Agent': `Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X)mxsa_mxbc`, + } + } + + await axios.request(opts); + $.log(`✅ 访问雪王铺:调用成功!`); + } catch (e) { + + $.log(`⛔️ 访问雪王铺:调用失败!${e}`); } } async task_signin() { try { + let time = Date.now() let options = { - url: `https://mxsa.mxbc.net/api/v1/customer/signin?appId=d82be6bbc1da11eb9dd000163e122ecb&t=${ts13()}&sign=${getSHA256withRSA('appId=d82be6bbc1da11eb9dd000163e122ecb&t=' + ts13())}`, + url: `https://mxsa.mxbc.net/api/v1/customer/signin?appId=d82be6bbc1da11eb9dd000163e122ecb&t=${time}&sign=${this.getSHA256withRSA('appId=d82be6bbc1da11eb9dd000163e122ecb&t=' + time)}`, headers: { - 'app': 'mxbc', - 'appchannel': 'xiaomi', - 'appversion': '3.0.3', - 'Access-Token': this.ck, 'Host': 'mxsa.mxbc.net', - 'Connection': 'Keep-Alive', - //'Accept-Encoding': 'gzip', - 'User-Agent': 'okhttp/4.4.1' + 'Connection': 'keep-alive', + 'user-agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 MicroMessenger/7.0.4.501 NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF', + 'xweb_xhr': 1, + 'Access-Token': this.ck, + 'Content-Type': 'application/json', + 'Accept': '*/*', + 'Sec-Fetch-Site': 'cross-site', + 'Sec-Fetch-Mode': 'cors', + 'Sec-Fetch-Dest': 'empty', + 'Referer': 'https://servicewechat.com/wx7696c66d2245d107/59/page-frame.html', + 'Accept-Language': 'en-us,en', + 'Accept-Encoding': 'gzip, deflate', + } } //console.log(options); - let result = await httpRequest(options); + let { data: result } = await axios.request(options); //console.log(result); if (result.code == 0) { - DoubleLog(`账号[${this.index}] 签到成功:累计签到 [${result.data.ruleValueGrowth}]天 本次获得[${result.data.ruleValuePoint}]币`); + $.log(`账号[${this.index}] 签到成功:累计签到 [${result.data.ruleValueGrowth}]天 本次获得[${result.data.ruleValuePoint}]币`); this.ckStatus = true } else { - DoubleLog(`账号[${this.index}] 签到:失败 ❌ 了呢,原因未知!`); + $.log(`账号[${this.index}] 签到:失败 ❌ 了呢,原因未知!`); console.log(result); } } catch (e) { console.log(e); } } + getSHA256withRSA(content) { + var rs = require("jsrsasign"); - - - -} - -!(async () => { - if (!(await checkEnv())) return; - if (userList.length > 0) { - await start(); - } - await SendMsg(msg); -})() - .catch((e) => console.log(e)) - .finally(() => $.done()); - - -//******************************************************** -// 变量检查与处理 -async function checkEnv() { - if (userCookie) { - // console.log(userCookie); - let e = envSplitor[0]; - for (let o of envSplitor) - if (userCookie.indexOf(o) > -1) { - e = o; - break; - } - for (let n of userCookie.split(e)) n && userList.push(new UserInfo(n)); - userCount = userList.length; - } else { - console.log("未找到CK"); - return; - } - return console.log(`共找到${userCount}个账号`), true;//true == !0 -} -///////////////////////////////////////////////////////////////////////////////////// -var rs = require("jsrsasign"); - -var privateKeyString = `-----BEGIN PRIVATE KEY----- + var privateKeyString = `-----BEGIN PRIVATE KEY----- MIIEvwIBADANBgkqhkiG9w0BAQEFAASCBKkwggSlAgEAAoIBAQCtypUdHZJKlQ9L L6lIJSphnhqjke7HclgWuWDRWvzov30du235cCm13mqJ3zziqLCwstdQkuXo9sOP Ih94t6nzBHTuqYA1whrUnQrKfv9X4/h3QVkzwT+xWflE+KubJZoe+daLKkDeZjVW @@ -193,111 +250,49 @@ ZNDBLCI2G4+UFP+8ZEuBKy5NkDVqXQhHRbqr9S/OkFu+kEjHLuYSpQsclh6XSDks dOGyw/X4SFyodv8AEloqd81yGg== -----END PRIVATE KEY----- `; -function getSHA256withRSA(content) { - const key = rs.KEYUTIL.getKey(privateKeyString); - const signature = new rs.KJUR.crypto.Signature({ alg: "SHA256withRSA" }); + const key = rs.KEYUTIL.getKey(privateKeyString); + + const signature = new rs.KJUR.crypto.Signature({ alg: "SHA256withRSA" }); + + signature.init(key); + + signature.updateString(content); + + const originSign = signature.sign(); + const sign64u = rs.hextob64u(originSign); + + return sign64u; + + } + + + - signature.init(key); - signature.updateString(content); - const originSign = signature.sign(); - const sign64u = rs.hextob64u(originSign); - return sign64u; } -/** - * 获取远程通知 - */ + +!(async () => { + await getNotice() + $.checkEnv(ckName); + + for (let user of $.userList) { + await new Task(user).run(); + } +})() + .catch((e) => console.log(e)) + .finally(() => $.done()); + async function getNotice() { - try { - const urls = [ - "https://ghproxy.com/https://raw.githubusercontent.com/smallfawn/Note/main/Notice.json", - "https://fastly.jsdelivr.net/gh/smallfawn/Note@main/Notice.json", - "https://cdn.jsdelivr.net/gh/smallfawn/Note@main/Notice.json", - "https://ghproxy.net/https://raw.githubusercontent.com/smallfawn/Note/refs/heads/main/Notice.json" - ]; - let notice = null; - for (const url of urls) { - const options = { - url, - headers: { "User-Agent": "" } - }; - const result = await httpRequest(options); - if (result && "notice" in result) { - notice = result.notice.replace(/\\n/g, '\n'); - break; - } + let options = { + url: `https://ghproxy.net/https://raw.githubusercontent.com/smallfawn/Note/refs/heads/main/Notice.json`, + headers: { + "User-Agent": defaultUserAgent, } - if (notice) { - DoubleLog(notice); - } - } catch (e) { - console.log(e); } -} -function ts13() { - return Math.round(new Date().getTime()).toString(); -} - -function httpRequest(options, method) { - //options = changeCode(options) - typeof (method) === 'undefined' ? ('body' in options ? method = 'post' : method = 'get') : method = method - return new Promise((resolve) => { - $[method](options, (err, resp, data) => { - try { - if (err) { - console.log(`${method}请求失败`); - //console.log(JSON.parse(err)); - $.logErr(err); - //throw new Error(err); - //console.log(err); - } else { - //httpResult = data; - //httpResponse = resp; - if (data) { - //console.log(data); - data = JSON.parse(data); - resolve(data) - } else { - console.log(`请求api返回数据为空,请检查自身原因`) - } - } - } catch (e) { - //console.log(e, resp); - $.logErr(e, resp); - } finally { - resolve(); - } - }) - }) -} -// 双平台log输出 -function DoubleLog(data) { - if ($.isNode()) { - if (data) { - console.log(`${data}`); - msg += `\n${data}` - } - } else { - console.log(`${data}`); - msg += `\n${data}` - } -} -// 发送消息 -async function SendMsg(message) { - if (!message) return; - if (Notify > 0) { - if ($.isNode()) { - var notify = require("./sendNotify"); - await notify.sendNotify($.name, message) - } else { - $.msg($.name, '', message) - } - } else { - console.log(message) - } -} -// 完整 Env -function Env(t, e) { "undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0); class s { constructor(t) { this.env = t } send(t, e = "GET") { t = "string" == typeof t ? { url: t } : t; let s = this.get; return "POST" === e && (s = this.post), new Promise((e, i) => { s.call(this, t, (t, s, r) => { t ? i(t) : e(s) }) }) } get(t) { return this.send.call(this.env, t) } post(t) { return this.send.call(this.env, t, "POST") } } return new class { constructor(t, e) { this.name = t, this.http = new s(this), this.data = null, this.dataFile = "box.dat", this.logs = [], this.isMute = !1, this.isNeedRewrite = !1, this.logSeparator = "\n", this.startTime = (new Date).getTime(), Object.assign(this, e), this.log("", `🔔${this.name}, 开始!`) } isNode() { return "undefined" != typeof module && !!module.exports } isQuanX() { return "undefined" != typeof $task } isSurge() { return "undefined" != typeof $httpClient && "undefined" == typeof $loon } isLoon() { return "undefined" != typeof $loon } toObj(t, e = null) { try { return JSON.parse(t) } catch { return e } } toStr(t, e = null) { try { return JSON.stringify(t) } catch { return e } } getjson(t, e) { let s = e; const i = this.getdata(t); if (i) try { s = JSON.parse(this.getdata(t)) } catch { } return s } setjson(t, e) { try { return this.setdata(JSON.stringify(t), e) } catch { return !1 } } getScript(t) { return new Promise(e => { this.get({ url: t }, (t, s, i) => e(i)) }) } runScript(t, e) { return new Promise(s => { let i = this.getdata("@chavy_boxjs_userCfgs.httpapi"); i = i ? i.replace(/\n/g, "").trim() : i; let r = this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout"); r = r ? 1 * r : 20, r = e && e.timeout ? e.timeout : r; const [o, h] = i.split("@"), n = { url: `http://${h}/v1/scripting/evaluate`, body: { script_text: t, mock_type: "cron", timeout: r }, headers: { "X-Key": o, Accept: "*/*" } }; this.post(n, (t, e, i) => s(i)) }).catch(t => this.logErr(t)) } loaddata() { if (!this.isNode()) return {}; { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e); if (!s && !i) return {}; { const i = s ? t : e; try { return JSON.parse(this.fs.readFileSync(i)) } catch (t) { return {} } } } } writedata() { if (this.isNode()) { this.fs = this.fs ? this.fs : require("fs"), this.path = this.path ? this.path : require("path"); const t = this.path.resolve(this.dataFile), e = this.path.resolve(process.cwd(), this.dataFile), s = this.fs.existsSync(t), i = !s && this.fs.existsSync(e), r = JSON.stringify(this.data); s ? this.fs.writeFileSync(t, r) : i ? this.fs.writeFileSync(e, r) : this.fs.writeFileSync(t, r) } } lodash_get(t, e, s) { const i = e.replace(/\[(\d+)\]/g, ".$1").split("."); let r = t; for (const t of i) if (r = Object(r)[t], void 0 === r) return s; return r } lodash_set(t, e, s) { return Object(t) !== t ? t : (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []), e.slice(0, -1).reduce((t, s, i) => Object(t[s]) === t[s] ? t[s] : t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}, t)[e[e.length - 1]] = s, t) } getdata(t) { let e = this.getval(t); if (/^@/.test(t)) { const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t), r = s ? this.getval(s) : ""; if (r) try { const t = JSON.parse(r); e = t ? this.lodash_get(t, i, "") : e } catch (t) { e = "" } } return e } setdata(t, e) { let s = !1; if (/^@/.test(e)) { const [, i, r] = /^@(.*?)\.(.*?)$/.exec(e), o = this.getval(i), h = i ? "null" === o ? null : o || "{}" : "{}"; try { const e = JSON.parse(h); this.lodash_set(e, r, t), s = this.setval(JSON.stringify(e), i) } catch (e) { const o = {}; this.lodash_set(o, r, t), s = this.setval(JSON.stringify(o), i) } } else s = this.setval(t, e); return s } getval(t) { return this.isSurge() || this.isLoon() ? $persistentStore.read(t) : this.isQuanX() ? $prefs.valueForKey(t) : this.isNode() ? (this.data = this.loaddata(), this.data[t]) : this.data && this.data[t] || null } setval(t, e) { return this.isSurge() || this.isLoon() ? $persistentStore.write(t, e) : this.isQuanX() ? $prefs.setValueForKey(t, e) : this.isNode() ? (this.data = this.loaddata(), this.data[e] = t, this.writedata(), !0) : this.data && this.data[e] || null } initGotEnv(t) { this.got = this.got ? this.got : require("got"), this.cktough = this.cktough ? this.cktough : require("tough-cookie"), this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar, t && (t.headers = t.headers ? t.headers : {}, void 0 === t.headers.Cookie && void 0 === t.cookieJar && (t.cookieJar = this.ckjar)) } get(t, e = (() => { })) { t.headers && (delete t.headers["Content-Type"], delete t.headers["Content-Length"]), this.isSurge() || this.isLoon() ? (this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.get(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) })) : this.isQuanX() ? (this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t))) : this.isNode() && (this.initGotEnv(t), this.got(t).on("redirect", (t, e) => { try { if (t.headers["set-cookie"]) { const s = t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString(); s && this.ckjar.setCookieSync(s, null), e.cookieJar = this.ckjar } } catch (t) { this.logErr(t) } }).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) })) } post(t, e = (() => { })) { if (t.body && t.headers && !t.headers["Content-Type"] && (t.headers["Content-Type"] = "application/x-www-form-urlencoded"), t.headers && delete t.headers["Content-Length"], this.isSurge() || this.isLoon()) this.isSurge() && this.isNeedRewrite && (t.headers = t.headers || {}, Object.assign(t.headers, { "X-Surge-Skip-Scripting": !1 })), $httpClient.post(t, (t, s, i) => { !t && s && (s.body = i, s.statusCode = s.status), e(t, s, i) }); else if (this.isQuanX()) t.method = "POST", this.isNeedRewrite && (t.opts = t.opts || {}, Object.assign(t.opts, { hints: !1 })), $task.fetch(t).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => e(t)); else if (this.isNode()) { this.initGotEnv(t); const { url: s, ...i } = t; this.got.post(s, i).then(t => { const { statusCode: s, statusCode: i, headers: r, body: o } = t; e(null, { status: s, statusCode: i, headers: r, body: o }, o) }, t => { const { message: s, response: i } = t; e(s, i, i && i.body) }) } } time(t, e = null) { const s = e ? new Date(e) : new Date; let i = { "M+": s.getMonth() + 1, "d+": s.getDate(), "H+": s.getHours(), "m+": s.getMinutes(), "s+": s.getSeconds(), "q+": Math.floor((s.getMonth() + 3) / 3), S: s.getMilliseconds() }; /(y+)/.test(t) && (t = t.replace(RegExp.$1, (s.getFullYear() + "").substr(4 - RegExp.$1.length))); for (let e in i) new RegExp("(" + e + ")").test(t) && (t = t.replace(RegExp.$1, 1 == RegExp.$1.length ? i[e] : ("00" + i[e]).substr(("" + i[e]).length))); return t } msg(e = t, s = "", i = "", r) { const o = t => { if (!t) return t; if ("string" == typeof t) return this.isLoon() ? t : this.isQuanX() ? { "open-url": t } : this.isSurge() ? { url: t } : void 0; if ("object" == typeof t) { if (this.isLoon()) { let e = t.openUrl || t.url || t["open-url"], s = t.mediaUrl || t["media-url"]; return { openUrl: e, mediaUrl: s } } if (this.isQuanX()) { let e = t["open-url"] || t.url || t.openUrl, s = t["media-url"] || t.mediaUrl; return { "open-url": e, "media-url": s } } if (this.isSurge()) { let e = t.url || t.openUrl || t["open-url"]; return { url: e } } } }; if (this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(e, s, i, o(r)) : this.isQuanX() && $notify(e, s, i, o(r))), !this.isMuteLog) { let t = ["", "==============📣系统通知📣=============="]; t.push(e), s && t.push(s), i && t.push(i), console.log(t.join("\n")), this.logs = this.logs.concat(t) } } log(...t) { t.length > 0 && (this.logs = [...this.logs, ...t]), console.log(t.join(this.logSeparator)) } logErr(t, e) { const s = !this.isSurge() && !this.isQuanX() && !this.isLoon(); s ? this.log("", `❗️${this.name}, 错误!`, t.stack) : this.log("", `❗️${this.name}, 错误!`, t) } wait(t) { return new Promise(e => setTimeout(e, t)) } done(t = {}) { const e = (new Date).getTime(), s = (e - this.startTime) / 1e3; this.log("", `🔔${this.name}, 结束! 🕛 ${s} 秒`), this.log(), (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t) } }(t, e) } + let { data: res } = await axios.request(options); + $.log(res) + return res +} \ No newline at end of file