mirror of
https://github.com/smallfawn/QLScriptPublic.git
synced 2026-01-15 23:10:42 +08:00
Compare commits
12 Commits
36dcb1938a
...
ef1ffcabbd
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ef1ffcabbd | ||
|
|
e5b8e8a8ed | ||
|
|
f6f56e8ffd | ||
|
|
dc2192f791 | ||
|
|
595fc5dbe7 | ||
|
|
5608b4a246 | ||
|
|
d082aac8da | ||
|
|
9b4f603953 | ||
|
|
ac04fa2067 | ||
|
|
111eb83f16 | ||
|
|
885c675d36 | ||
|
|
1cc77a8aab |
@ -22,7 +22,7 @@ const $ = new Env("安慕希小程序");
|
||||
let ckName = `anmuxi`;
|
||||
const strSplitor = "#";
|
||||
const envSplitor = ["&", "\n"];
|
||||
const notify = $.isNode() ? require("./sendNotify") : "";
|
||||
const notify = $.isNode() ? require("../sendNotify") : "";
|
||||
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"
|
||||
|
||||
|
||||
@ -557,7 +557,7 @@ function _0x2fbb6b(_0x5a60f2) {
|
||||
{
|
||||
if (!this.notifyFlag) return;
|
||||
if (!this.notifyStr.length) return;
|
||||
var _0x29aa8f = require("./sendNotify");
|
||||
var _0x29aa8f = require("../sendNotify");
|
||||
this.log("\n============== 推送 ==============");
|
||||
await _0x29aa8f.sendNotify(this.name, this.notifyStr.join("\n"));
|
||||
}
|
||||
|
||||
@ -4,7 +4,9 @@
|
||||
@Date: 2024.06.07 19:15
|
||||
@Description: 测试
|
||||
------------------------------------------
|
||||
#Notice:
|
||||
#Notice: 只适用于购买了luflytoken的 购买联系QQ860562056
|
||||
变量luflytoken 填写luflytoken
|
||||
变量wxbnmdwxid 填写wxbnmdwxid 多账号&分割或者换行
|
||||
⚠️【免责声明】
|
||||
------------------------------------------
|
||||
1、此脚本仅用于学习研究,不保证其合法性、准确性、有效性,请根据情况自行判断,本人对此不承担任何保证责任。
|
||||
@ -17,14 +19,17 @@
|
||||
*/
|
||||
|
||||
const $ = new Env("巴奴毛肚小程序");
|
||||
let ckName = `testA`;
|
||||
let ckName = `wxbnmdwxid`;
|
||||
const strSplitor = "#";
|
||||
const envSplitor = ["&", "\n"];
|
||||
process.env[ckName] = "testA#testB&testC#testD"
|
||||
const notify = $.isNode() ? require("./sendNotify") : "";
|
||||
const crypto = require("crypto-js");
|
||||
const notify = $.isNode() ? require("../sendNotify") : "";
|
||||
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"
|
||||
|
||||
const key = "bfc5e947cd84c7ced1ee48d28fb3e90f";
|
||||
let luflytoken = process.env.luflytoken || ""
|
||||
let wxcenter = 'http://w.smallfawn.top:5789'
|
||||
let appid = 'wx71373698c47f9a9f'
|
||||
class Public {
|
||||
async request(options) {
|
||||
return await axios.request(options);
|
||||
@ -35,17 +40,158 @@ class Task extends Public {
|
||||
|
||||
super();
|
||||
this.index = $.userIdx++
|
||||
let user = env.split("#");
|
||||
this.name = user[0];
|
||||
this.passwd = user[1];
|
||||
let user = env.split(strSplitor);
|
||||
this.wxid = user[0];
|
||||
}
|
||||
getUUID(_0x4b4b65 = 16, _0x14813d = 36) {
|
||||
const _0x181bd6 = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");
|
||||
const _0x295ca7 = [];
|
||||
let _0x4713fe = 0;
|
||||
if (_0x4b4b65) {
|
||||
for (_0x4713fe = 0; _0x4713fe < _0x4b4b65; _0x4713fe++) {
|
||||
_0x295ca7[_0x4713fe] = _0x181bd6[0 | Math.random() * _0x14813d];
|
||||
}
|
||||
} else {
|
||||
let _0x540406;
|
||||
for (_0x295ca7[8] = _0x295ca7[13] = _0x295ca7[18] = _0x295ca7[23] = "-", _0x295ca7[14] = "4", _0x4713fe = 0; _0x4713fe < 36; _0x4713fe++) {
|
||||
if (!_0x295ca7[_0x4713fe]) {
|
||||
_0x540406 = 0 | 16 * Math.random();
|
||||
_0x295ca7[_0x4713fe] = _0x181bd6[19 === _0x4713fe ? 3 & _0x540406 | 8 : _0x540406];
|
||||
}
|
||||
}
|
||||
}
|
||||
return _0x295ca7.join("");
|
||||
}
|
||||
getHeaders(options, _0x32d686, authorization) {
|
||||
const keyOptions = {
|
||||
app_key: "KlZ4LqOF",
|
||||
app_secret: "HoBJTYXdwn"
|
||||
};
|
||||
const _0x3aaf0a = {
|
||||
t: Math.floor(new Date().getTime() / 1000),
|
||||
n: this.getUUID(),
|
||||
...keyOptions
|
||||
};
|
||||
const _0x419328 = Object.values(_0x3aaf0a).join("");
|
||||
|
||||
const sign = this.stringToLowerCase(this.stringToLowerCase(_0x419328)).split("").reverse().join("");
|
||||
const header = {
|
||||
'Connection': 'keep-alive',
|
||||
'content-type': 'application/json',
|
||||
'uuid': options.uuid,
|
||||
'platform_version_code': 'iOS 16.6',
|
||||
'authorization': authorization, //
|
||||
'tenancy_id': 'banu',
|
||||
'app_key': 'KlZ4LqOF',
|
||||
'code': 'f22b68d1c74c3a66aa7a1b199bcd4e20', //
|
||||
'platform_version_name': 'iPhone 11<iPhone12,1>',
|
||||
'platform_version_weapp': '8.0.50',
|
||||
't': _0x3aaf0a.t,
|
||||
'n': _0x3aaf0a.n,
|
||||
'platform_version_sdk': '3.5.8',
|
||||
'sign': sign,
|
||||
'User-Agent': 'Mozilla/5.0 (iPhone; CPU iPhone OS 16_6 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 MicroMessenger/8.0.50(0x1800323d) NetType/4G Language/zh_CN',
|
||||
'Referer': 'https://servicewechat.com/wx71373698c47f9a9f/474/page-frame.html'
|
||||
}
|
||||
|
||||
if (_0x32d686) {
|
||||
const _0xa2075e = new URLSearchParams({
|
||||
...options,
|
||||
enc_data: _0x32d686
|
||||
}).toString();
|
||||
const code = this.stringToLowerCase(this.stringToLowerCase(_0xa2075e)).split("").reverse().join("");
|
||||
header.code = code;
|
||||
}
|
||||
return header;
|
||||
}
|
||||
stringToLowerCase(str) {
|
||||
return crypto.MD5(str).toString().toLowerCase();
|
||||
}
|
||||
decrypt(_0x3c73c4) {
|
||||
const _0x3218f0 = crypto.lib.WordArray.random(16).toString();
|
||||
const _0x30b65e = JSON.stringify(_0x3c73c4);
|
||||
const _0x429ee1 = crypto.AES.encrypt(_0x30b65e, crypto.enc.Utf8.parse(key), {
|
||||
iv: crypto.enc.Utf8.parse(_0x3218f0),
|
||||
mode: crypto.mode.CBC
|
||||
}).toString();
|
||||
return crypto.enc.Base64.stringify(crypto.enc.Utf8.parse(JSON.stringify({
|
||||
iv: _0x3218f0,
|
||||
encrypted_data: _0x429ee1
|
||||
})));
|
||||
}
|
||||
async getcode() {
|
||||
let options = {
|
||||
url: `${wxcenter}/api/getcode`,
|
||||
headers: {
|
||||
'Content-Type': 'application/json'
|
||||
},
|
||||
method: 'POST',
|
||||
data: { "luflyKey": "" + luflytoken, "wxid": "" + this.wxid, "appid": "" + appid }
|
||||
}
|
||||
let { data: result } = await this.request(options);
|
||||
if (result.status) {
|
||||
let code = result.data
|
||||
$.log(`账号[${this.wxid}] 获取code成功[${code}]`);
|
||||
let { member_id: memberId, openid: authorization } = await this.login(code)
|
||||
const headerObj = {};
|
||||
const data = {
|
||||
member_id: memberId
|
||||
};
|
||||
try {
|
||||
headerObj.uuid = this.getUUID();
|
||||
const res = await axios.get("https://cloud.banu.cn/api/sign-in/days", {
|
||||
params: data,
|
||||
headers: this.getHeaders(headerObj, false, authorization)
|
||||
});
|
||||
if (res.data.data.is_sign_in) {
|
||||
$.log(`账号[${this.wxid}] 重复签到`);
|
||||
} else {
|
||||
const decryptData = this.decrypt(data);
|
||||
const res = await axios.post("https://cloud.banu.cn/api/sign-in", {
|
||||
enc_data: decryptData
|
||||
}, {
|
||||
headers: this.getHeaders(headerObj, decryptData, authorization)
|
||||
});
|
||||
$.log("签到:" + res.data.message);
|
||||
}
|
||||
const info = await axios.get("https://cloud.banu.cn/api/member/statistic", {
|
||||
params: data,
|
||||
headers: this.getHeaders(headerObj, false, authorization)
|
||||
});
|
||||
const result = "\nMember_id:" + memberId + "\n用户名:" + info.data.data.name + "\n总积分:" + info.data.data.points;
|
||||
} catch (err) {
|
||||
|
||||
console.log("签到失败:" + err + " | 签到时间:" + Date.now());
|
||||
}
|
||||
} else {
|
||||
console.log(result);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
async login(code) {
|
||||
let url = 'https://cloud.banu.cn/api/wx/weapp/auth';
|
||||
let data = {
|
||||
'app_id': 'wx71373698c47f9a9f',
|
||||
'code': code
|
||||
}
|
||||
const headerObj = {};
|
||||
headerObj.uuid = this.getUUID();
|
||||
let headers = this.getHeaders(headerObj, false, "");
|
||||
|
||||
let { data: res } = await this.request({
|
||||
url,
|
||||
method: "POST",
|
||||
headers,
|
||||
data
|
||||
})
|
||||
return res.data;
|
||||
}
|
||||
async run() {
|
||||
|
||||
await this.getcode()
|
||||
|
||||
|
||||
console.log(this.index);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
311
wxapp/hdl.js
Normal file
311
wxapp/hdl.js
Normal file
@ -0,0 +1,311 @@
|
||||
/*
|
||||
------------------------------------------
|
||||
@Author: sm
|
||||
@Date: 2024.06.07 19:15
|
||||
@Description: 海底捞
|
||||
cron: 12 12 * * *
|
||||
------------------------------------------
|
||||
#Notice:
|
||||
https://superapp-public.kiwa-tech.com/api/gateway/login/center/login/wechatLogin 接口的请求参数openId#uid
|
||||
填写到变量名为haidilao的值中 多账号&或换行
|
||||
|
||||
⚠️【免责声明】
|
||||
------------------------------------------
|
||||
1、此脚本仅用于学习研究,不保证其合法性、准确性、有效性,请根据情况自行判断,本人对此不承担任何保证责任。
|
||||
2、由于此脚本仅用于学习研究,您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除,若违反规定引起任何事件本人对此均不负责。
|
||||
3、请勿将此脚本用于任何商业或非法目的,若违反规定请自行对此负责。
|
||||
4、此脚本涉及应用与本人无关,本人对因此引起的任何隐私泄漏或其他后果不承担任何责任。
|
||||
5、本人对任何脚本引发的问题概不负责,包括但不限于由脚本错误引起的任何损失和损害。
|
||||
6、如果任何单位或个人认为此脚本可能涉嫌侵犯其权利,应及时通知并提供身份证明,所有权证明,我们将在收到认证文件确认后删除此脚本。
|
||||
7、所有直接或间接使用、查看此脚本的人均应该仔细阅读此声明。本人保留随时更改或补充此声明的权利。一旦您使用或复制了此脚本,即视为您已接受此免责声明。
|
||||
*/
|
||||
|
||||
const $ = new Env("海底捞");
|
||||
let ckName = `haidilao`;
|
||||
const strSplitor = "#";
|
||||
const envSplitor = ["&", "\n"];
|
||||
const notify = $.isNode() ? require("../sendNotify") : "";
|
||||
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"
|
||||
|
||||
let appid = 'wx54f3e6a00f7973a7'
|
||||
class Public {
|
||||
async request(options) {
|
||||
return await axios.request(options);
|
||||
}
|
||||
}
|
||||
class Task extends Public {
|
||||
constructor(env) {
|
||||
|
||||
super();
|
||||
this.index = $.userIdx++
|
||||
let user = env.split(strSplitor);
|
||||
this.openId = user[0];
|
||||
this.uid = user[1];
|
||||
}
|
||||
|
||||
|
||||
async login() {
|
||||
|
||||
|
||||
let options = {
|
||||
url: "https://superapp-public.kiwa-tech.com/api/gateway/login/center/login/wechatLogin",
|
||||
headers: {
|
||||
"_haidilao_app_token": "",
|
||||
"accept": "*/*",
|
||||
"accept-language": "zh-CN,zh;q=0.9",
|
||||
"appid": "15",
|
||||
"appname": "HDLMember",
|
||||
"appversion": "3.240.0",
|
||||
"content-type": "application/json",
|
||||
"platformname": "wechat",
|
||||
"sec-fetch-dest": "empty",
|
||||
"sec-fetch-mode": "cors",
|
||||
"sec-fetch-site": "cross-site",
|
||||
"smdeviceid": "",
|
||||
"xweb_xhr": "1"
|
||||
},
|
||||
method: 'POST',
|
||||
data: {
|
||||
"type": 1,
|
||||
"country": "CN",
|
||||
"codeType": 1,
|
||||
"business": "登录",
|
||||
"terminal": "会员小程序",
|
||||
"openId": "" + this.openId,
|
||||
"uid": "" + this.uid
|
||||
}
|
||||
}
|
||||
let { data: result } = await this.request(options);
|
||||
if (result.code == 100000) {
|
||||
this.token = result.data.token
|
||||
this.name = result.data.nickName
|
||||
$.log(`账号[${this.index}]【${this.name}】 登录成功`);
|
||||
await this.signIn()
|
||||
await this.info()
|
||||
} else {
|
||||
console.log(result);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
async signIn() {
|
||||
let options = {
|
||||
url: 'https://superapp-public.kiwa-tech.com/activity/wxapp/signin/signin',
|
||||
headers: {
|
||||
'_haidilao_app_token': this.token,
|
||||
|
||||
},
|
||||
method: 'POST',
|
||||
data: { "signinSource": "MiniApp" }
|
||||
}
|
||||
let { data: result } = await this.request(options);
|
||||
if (result['success']) {
|
||||
$.log(`账号[${this.index}]【${this.name}】 签到成功`);
|
||||
} else {
|
||||
console.log(result);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
async info() {
|
||||
let options = {
|
||||
url: 'https://superapp-public.kiwa-tech.com/activity/wxapp/signin/queryFragment',
|
||||
headers: {
|
||||
'_haidilao_app_token': this.token,
|
||||
|
||||
},
|
||||
method: 'POST',
|
||||
data: {}
|
||||
}
|
||||
let { data: result } = await this.request(options);
|
||||
if (result['success']) {
|
||||
$.log(`账号[${this.index}] 剩余[${result.data.total}]本期碎片将于${result['data']['expireDate']}过期 `)
|
||||
} else {
|
||||
console.log(result);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
async run() {
|
||||
await this.login()
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
!(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://gitee.com/smallfawn/Note/raw/main/Notice.json`,
|
||||
headers: {
|
||||
"User-Agent": defaultUserAgent,
|
||||
}
|
||||
}
|
||||
let { data: res } = await new Public().request(options);
|
||||
$.log(res)
|
||||
return res
|
||||
}
|
||||
|
||||
|
||||
// prettier-ignore
|
||||
function Env(t, s) {
|
||||
return new (class {
|
||||
constructor(t, s) {
|
||||
this.userIdx = 1;
|
||||
this.userList = [];
|
||||
this.userCount = 0;
|
||||
this.name = t;
|
||||
this.notifyStr = [];
|
||||
this.logSeparator = "\n";
|
||||
this.startTime = new Date().getTime();
|
||||
Object.assign(this, s);
|
||||
this.log(`\ud83d\udd14${this.name},\u5f00\u59cb!`);
|
||||
}
|
||||
checkEnv(ckName) {
|
||||
let userCookie = (this.isNode() ? process.env[ckName] : "") || "";
|
||||
this.userList = userCookie.split(envSplitor.find((o) => userCookie.includes(o)) || "&").filter((n) => n);
|
||||
this.userCount = this.userList.length;
|
||||
this.log(`共找到${this.userCount}个账号`);
|
||||
}
|
||||
async sendMsg() {
|
||||
this.log("==============📣Center 通知📣==============")
|
||||
let message = this.notifyStr.join(this.logSeparator);
|
||||
if (this.isNode()) {
|
||||
|
||||
await notify.sendNotify(this.name, message);
|
||||
} else {
|
||||
|
||||
}
|
||||
}
|
||||
isNode() {
|
||||
return "undefined" != typeof module && !!module.exports;
|
||||
}
|
||||
|
||||
queryStr(options) {
|
||||
return Object.entries(options)
|
||||
.map(
|
||||
([key, value]) =>
|
||||
`${key}=${typeof value === "object" ? JSON.stringify(value) : value
|
||||
}`
|
||||
)
|
||||
.join("&");
|
||||
}
|
||||
getURLParams(url) {
|
||||
const params = {};
|
||||
const queryString = url.split("?")[1];
|
||||
if (queryString) {
|
||||
const paramPairs = queryString.split("&");
|
||||
paramPairs.forEach((pair) => {
|
||||
const [key, value] = pair.split("=");
|
||||
params[key] = value;
|
||||
});
|
||||
}
|
||||
return params;
|
||||
}
|
||||
isJSONString(str) {
|
||||
try {
|
||||
return JSON.parse(str) && typeof JSON.parse(str) === "object";
|
||||
} catch (e) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
isJson(obj) {
|
||||
var isjson =
|
||||
typeof obj == "object" &&
|
||||
Object.prototype.toString.call(obj).toLowerCase() ==
|
||||
"[object object]" &&
|
||||
!obj.length;
|
||||
return isjson;
|
||||
}
|
||||
|
||||
randomNumber(length) {
|
||||
const characters = "0123456789";
|
||||
return Array.from(
|
||||
{ length },
|
||||
() => characters[Math.floor(Math.random() * characters.length)]
|
||||
).join("");
|
||||
}
|
||||
randomString(length) {
|
||||
const characters = "abcdefghijklmnopqrstuvwxyz0123456789";
|
||||
return Array.from(
|
||||
{ length },
|
||||
() => characters[Math.floor(Math.random() * characters.length)]
|
||||
).join("");
|
||||
}
|
||||
uuid() {
|
||||
return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(
|
||||
/[xy]/g,
|
||||
function (c) {
|
||||
var r = (Math.random() * 16) | 0,
|
||||
v = c == "x" ? r : (r & 0x3) | 0x8;
|
||||
return v.toString(16);
|
||||
}
|
||||
);
|
||||
}
|
||||
time(t) {
|
||||
let s = {
|
||||
"M+": new Date().getMonth() + 1,
|
||||
"d+": new Date().getDate(),
|
||||
"H+": new Date().getHours(),
|
||||
"m+": new Date().getMinutes(),
|
||||
"s+": new Date().getSeconds(),
|
||||
"q+": Math.floor((new Date().getMonth() + 3) / 3),
|
||||
S: new Date().getMilliseconds(),
|
||||
};
|
||||
/(y+)/.test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
(new Date().getFullYear() + "").substr(4 - RegExp.$1.length)
|
||||
));
|
||||
for (let e in s) {
|
||||
new RegExp("(" + e + ")").test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
1 == RegExp.$1.length
|
||||
? s[e]
|
||||
: ("00" + s[e]).substr(("" + s[e]).length)
|
||||
));
|
||||
}
|
||||
return t;
|
||||
}
|
||||
|
||||
log(content) {
|
||||
this.notifyStr.push(content)
|
||||
console.log(content)
|
||||
}
|
||||
wait(t) {
|
||||
return new Promise((s) => setTimeout(s, t));
|
||||
}
|
||||
done(t = {}) {
|
||||
this.sendMsg();
|
||||
const s = new Date().getTime(),
|
||||
e = (s - this.startTime) / 1e3;
|
||||
this.log(
|
||||
`\ud83d\udd14${this.name},\u7ed3\u675f!\ud83d\udd5b ${e}\u79d2`
|
||||
);
|
||||
if (this.isNode()) {
|
||||
process.exit(1);
|
||||
}
|
||||
}
|
||||
})(t, s);
|
||||
}
|
||||
286
wxapp/kangshifu.js
Normal file
286
wxapp/kangshifu.js
Normal file
@ -0,0 +1,286 @@
|
||||
/*
|
||||
------------------------------------------
|
||||
@Author: sm
|
||||
@Date: 2024.06.07 19:15
|
||||
@Description: 康师傅
|
||||
cron: 12 12 * * *
|
||||
------------------------------------------
|
||||
#Notice: 只适用于购买了luflytoken的 购买联系QQ860562056
|
||||
变量luflytoken 填写luflytoken
|
||||
变量wxkangshifuwxid 填写wxkangshifuwxid 多账号&分割或者换行
|
||||
|
||||
⚠️【免责声明】
|
||||
------------------------------------------
|
||||
1、此脚本仅用于学习研究,不保证其合法性、准确性、有效性,请根据情况自行判断,本人对此不承担任何保证责任。
|
||||
2、由于此脚本仅用于学习研究,您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除,若违反规定引起任何事件本人对此均不负责。
|
||||
3、请勿将此脚本用于任何商业或非法目的,若违反规定请自行对此负责。
|
||||
4、此脚本涉及应用与本人无关,本人对因此引起的任何隐私泄漏或其他后果不承担任何责任。
|
||||
5、本人对任何脚本引发的问题概不负责,包括但不限于由脚本错误引起的任何损失和损害。
|
||||
6、如果任何单位或个人认为此脚本可能涉嫌侵犯其权利,应及时通知并提供身份证明,所有权证明,我们将在收到认证文件确认后删除此脚本。
|
||||
7、所有直接或间接使用、查看此脚本的人均应该仔细阅读此声明。本人保留随时更改或补充此声明的权利。一旦您使用或复制了此脚本,即视为您已接受此免责声明。
|
||||
*/
|
||||
|
||||
const $ = new Env("康师傅");
|
||||
let ckName = `wxkangshifuwxid`;
|
||||
const strSplitor = "#";
|
||||
const envSplitor = ["&", "\n"];
|
||||
const notify = $.isNode() ? require("../sendNotify") : "";
|
||||
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"
|
||||
let luflytoken = process.env.luflytoken || ""
|
||||
let wxcenter = 'http://w.smallfawn.top:5789'
|
||||
let appid = 'wx54f3e6a00f7973a7'
|
||||
class Public {
|
||||
async request(options) {
|
||||
return await axios.request(options);
|
||||
}
|
||||
}
|
||||
class Task extends Public {
|
||||
constructor(env) {
|
||||
|
||||
super();
|
||||
this.index = $.userIdx++
|
||||
let user = env.split(strSplitor);
|
||||
this.wxid = user[0];
|
||||
this.passwd = user[1];
|
||||
}
|
||||
|
||||
async getcode() {
|
||||
let options = {
|
||||
url: `${wxcenter}/api/getcode`,
|
||||
headers: {
|
||||
'Content-Type': 'application/json'
|
||||
},
|
||||
method: 'POST',
|
||||
data: { "luflyKey": "" + luflytoken, "wxid": "" + this.wxid, "appid": "" + appid }
|
||||
}
|
||||
let { data: result } = await this.request(options);
|
||||
if (result.status) {
|
||||
let code = result.data
|
||||
$.log(`账号[${this.index}]【${this.name}】 获取code成功[${code}]`);
|
||||
await this.login(code)
|
||||
} else {
|
||||
console.log(result);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
async login(code) {
|
||||
let options = {
|
||||
url: `https://nclub.gdshcm.com/pro/whale-member/api/login/login`,
|
||||
headers: {
|
||||
'Content-Type': 'application/json'
|
||||
},
|
||||
method: 'POST',
|
||||
data: { "code": "" + code, "inviterId": "", "inviterType": 1, "inviterMatchUserId": "", "spUrl": null }
|
||||
}
|
||||
let { data: result } = await this.request(options);
|
||||
if (result.code == 0) {
|
||||
let token = result.data.token
|
||||
$.log(`账号[${this.index}]【${this.name}】 登录成功`);
|
||||
await this.signIn(token)
|
||||
} else {
|
||||
console.log(result);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
async signIn(token) {
|
||||
let options = {
|
||||
url: ` https://club.biqr.cn/api/signIn/integralSignIn`,
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
'token': "" + token
|
||||
},
|
||||
method: 'POST',
|
||||
data: {}
|
||||
}
|
||||
let { data: result } = await this.request(options);
|
||||
if (result.code == 0) {
|
||||
$.log(`账号[${this.index}]【${this.name}】 签到成功`);
|
||||
} else {
|
||||
console.log(result);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
async run() {
|
||||
await this.getcode()
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
!(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://gitee.com/smallfawn/Note/raw/main/Notice.json`,
|
||||
headers: {
|
||||
"User-Agent": defaultUserAgent,
|
||||
}
|
||||
}
|
||||
let { data: res } = await new Public().request(options);
|
||||
$.log(res)
|
||||
return res
|
||||
}
|
||||
|
||||
|
||||
// prettier-ignore
|
||||
function Env(t, s) {
|
||||
return new (class {
|
||||
constructor(t, s) {
|
||||
this.userIdx = 1;
|
||||
this.userList = [];
|
||||
this.userCount = 0;
|
||||
this.name = t;
|
||||
this.notifyStr = [];
|
||||
this.logSeparator = "\n";
|
||||
this.startTime = new Date().getTime();
|
||||
Object.assign(this, s);
|
||||
this.log(`\ud83d\udd14${this.name},\u5f00\u59cb!`);
|
||||
}
|
||||
checkEnv(ckName) {
|
||||
let userCookie = (this.isNode() ? process.env[ckName] : "") || "";
|
||||
this.userList = userCookie.split(envSplitor.find((o) => userCookie.includes(o)) || "&").filter((n) => n);
|
||||
this.userCount = this.userList.length;
|
||||
this.log(`共找到${this.userCount}个账号`);
|
||||
}
|
||||
async sendMsg() {
|
||||
this.log("==============📣Center 通知📣==============")
|
||||
let message = this.notifyStr.join(this.logSeparator);
|
||||
if (this.isNode()) {
|
||||
|
||||
await notify.sendNotify(this.name, message);
|
||||
} else {
|
||||
|
||||
}
|
||||
}
|
||||
isNode() {
|
||||
return "undefined" != typeof module && !!module.exports;
|
||||
}
|
||||
|
||||
queryStr(options) {
|
||||
return Object.entries(options)
|
||||
.map(
|
||||
([key, value]) =>
|
||||
`${key}=${typeof value === "object" ? JSON.stringify(value) : value
|
||||
}`
|
||||
)
|
||||
.join("&");
|
||||
}
|
||||
getURLParams(url) {
|
||||
const params = {};
|
||||
const queryString = url.split("?")[1];
|
||||
if (queryString) {
|
||||
const paramPairs = queryString.split("&");
|
||||
paramPairs.forEach((pair) => {
|
||||
const [key, value] = pair.split("=");
|
||||
params[key] = value;
|
||||
});
|
||||
}
|
||||
return params;
|
||||
}
|
||||
isJSONString(str) {
|
||||
try {
|
||||
return JSON.parse(str) && typeof JSON.parse(str) === "object";
|
||||
} catch (e) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
isJson(obj) {
|
||||
var isjson =
|
||||
typeof obj == "object" &&
|
||||
Object.prototype.toString.call(obj).toLowerCase() ==
|
||||
"[object object]" &&
|
||||
!obj.length;
|
||||
return isjson;
|
||||
}
|
||||
|
||||
randomNumber(length) {
|
||||
const characters = "0123456789";
|
||||
return Array.from(
|
||||
{ length },
|
||||
() => characters[Math.floor(Math.random() * characters.length)]
|
||||
).join("");
|
||||
}
|
||||
randomString(length) {
|
||||
const characters = "abcdefghijklmnopqrstuvwxyz0123456789";
|
||||
return Array.from(
|
||||
{ length },
|
||||
() => characters[Math.floor(Math.random() * characters.length)]
|
||||
).join("");
|
||||
}
|
||||
uuid() {
|
||||
return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(
|
||||
/[xy]/g,
|
||||
function (c) {
|
||||
var r = (Math.random() * 16) | 0,
|
||||
v = c == "x" ? r : (r & 0x3) | 0x8;
|
||||
return v.toString(16);
|
||||
}
|
||||
);
|
||||
}
|
||||
time(t) {
|
||||
let s = {
|
||||
"M+": new Date().getMonth() + 1,
|
||||
"d+": new Date().getDate(),
|
||||
"H+": new Date().getHours(),
|
||||
"m+": new Date().getMinutes(),
|
||||
"s+": new Date().getSeconds(),
|
||||
"q+": Math.floor((new Date().getMonth() + 3) / 3),
|
||||
S: new Date().getMilliseconds(),
|
||||
};
|
||||
/(y+)/.test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
(new Date().getFullYear() + "").substr(4 - RegExp.$1.length)
|
||||
));
|
||||
for (let e in s) {
|
||||
new RegExp("(" + e + ")").test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
1 == RegExp.$1.length
|
||||
? s[e]
|
||||
: ("00" + s[e]).substr(("" + s[e]).length)
|
||||
));
|
||||
}
|
||||
return t;
|
||||
}
|
||||
|
||||
log(content) {
|
||||
this.notifyStr.push(content)
|
||||
console.log(content)
|
||||
}
|
||||
wait(t) {
|
||||
return new Promise((s) => setTimeout(s, t));
|
||||
}
|
||||
done(t = {}) {
|
||||
this.sendMsg();
|
||||
const s = new Date().getTime(),
|
||||
e = (s - this.startTime) / 1e3;
|
||||
this.log(
|
||||
`\ud83d\udd14${this.name},\u7ed3\u675f!\ud83d\udd5b ${e}\u79d2`
|
||||
);
|
||||
if (this.isNode()) {
|
||||
process.exit(1);
|
||||
}
|
||||
}
|
||||
})(t, s);
|
||||
}
|
||||
@ -11,7 +11,7 @@
|
||||
*/
|
||||
|
||||
const $ = new Env("微信小程序_骁龙骁友会");
|
||||
const notify = $.isNode() ? require('./sendNotify') : '';
|
||||
const notify = $.isNode() ? require('../sendNotify') : '';
|
||||
let ckName = "wx_xlxyh";
|
||||
let envSplitor = ["&", "\n"]; //多账号分隔符
|
||||
let strSplitor = "#"; //多变量分隔符
|
||||
|
||||
@ -1,8 +1,11 @@
|
||||
/**
|
||||
* cron 25 10 * * * wx_ZIWI+.js
|
||||
* 积分换 猫粮狗粮
|
||||
* 变量名:ZIWIAUTH
|
||||
* 变量值:https://ziwi.gzcrm.cn/json-rpc? Headers中的authorization 去掉Bearer 去掉Bearer 去掉Bearer
|
||||
* 变量名wxziwiwxid 值为lufly登录授权的微信id 用于获取微信CODE 来刷新CK
|
||||
* 变量名luflytoken 谨慎使用加密本 防止偷取TOKEN
|
||||
*
|
||||
*
|
||||
*
|
||||
* 多账号& 或新增变量
|
||||
* scriptVersionNow = "0.0.1";
|
||||
*/
|
||||
@ -14,23 +17,58 @@ let envSplitor = ["&", "\n"]; //多账号分隔符
|
||||
let strSplitor = "#"; //多变量分隔符
|
||||
let userIdx = 0;
|
||||
let userList = [];
|
||||
let msg = ""
|
||||
let appid = 'wxb26a710e583b05dc'
|
||||
let wxcenter = 'http://w.smallfawn.top:5789'
|
||||
class Task {
|
||||
constructor(str) {
|
||||
this.index = ++userIdx;
|
||||
this.ck = str.split(strSplitor)[0]; //单账号多变量分隔符
|
||||
this.wxid = str.split(strSplitor) //单账号多变量分隔符
|
||||
this.ckStatus = true;
|
||||
//定义在这里的headers会被get请求删掉content-type 而不会重置
|
||||
this.artList = []
|
||||
this.ck = ''
|
||||
}
|
||||
async main() {
|
||||
await this.task_sign()
|
||||
await this.act_list();
|
||||
if (this.artList.length > 0) {
|
||||
for (let act of this.artList) {
|
||||
await this.task_like(act)
|
||||
await this.task_share(act)
|
||||
|
||||
await this.getCode()
|
||||
|
||||
}
|
||||
async getCode() {
|
||||
let { body: result } = await $.httpRequest({
|
||||
method: 'post', headers: {
|
||||
'Content-Type': 'application/json'
|
||||
}, url: wxcenter + '/api/getcode', body: JSON.stringify({ "luflyKey": process.env['luflytoken'], "wxid": "" + this.wxid, "appid": "wxb26a710e583b05dc" })
|
||||
})
|
||||
if (result) {
|
||||
console.log(result)
|
||||
if (result.status) {
|
||||
let code = result.data
|
||||
|
||||
await this.getJwtByCode(code)
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
async getJwtByCode(code) {
|
||||
|
||||
let result = await this.taskRequest('post', 'https://ziwi.gzcrm.cn/json-rpc?__method=WechatMiniProgramCodeToSession', { "id": "", "jsonrpc": "2.0", "method": "WechatMiniProgramCodeToSession", "params": { "appId": "wxb26a710e583b05dc", "code": "" + code, "launchOptions": { "path": "pages/index/index", "query": {}, "referrerInfo": {}, "apiCategory": "default" } } })
|
||||
if (result) {
|
||||
if ('result' in result) {
|
||||
if ('jwt' in result.result) {
|
||||
console.log(`刷新CK成功`)
|
||||
this.ck = result.result.jwt
|
||||
await this.task_sign()
|
||||
await this.act_list();
|
||||
if (this.artList.length > 0) {
|
||||
for (let act of this.artList) {
|
||||
await this.task_like(act)
|
||||
await this.task_share(act)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
async taskRequest(method, url, body = "") {
|
||||
@ -39,7 +77,7 @@ class Task {
|
||||
"Host": "ziwi.gzcrm.cn",
|
||||
"Connection": "keep-alive",
|
||||
//"Content-Length": "85",
|
||||
"authorization": "Bearer "+ this.ck,
|
||||
"authorization": "Bearer " + this.ck,
|
||||
"charset": "utf-8",
|
||||
"User-Agent": "Mozilla/5.0 (Linux; Android 10; MI 8 Lite Build/QKQ1.190910.002; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/116.0.0.0 Mobile Safari/537.36 XWEB/1160027 MMWEBSDK/20231002 MMWEBID/2585 MicroMessenger/8.0.43.2480(0x28002B51) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 MiniProgramEnv/android",
|
||||
"content-type": "application/json;charset=UTF-8",
|
||||
|
||||
@ -21,7 +21,7 @@ const $ = new Env("可口可乐吧");
|
||||
let ckName = `kekoukeleba`;
|
||||
const strSplitor = "#";
|
||||
const envSplitor = ["&", "\n"];
|
||||
const notify = $.isNode() ? require("./sendNotify") : "";
|
||||
const notify = $.isNode() ? require("../sendNotify") : "";
|
||||
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"
|
||||
|
||||
|
||||
@ -21,7 +21,7 @@ const $ = new Env("杰士邦会员中心");
|
||||
let ckName = `jieshibang`;
|
||||
const strSplitor = "#";
|
||||
const envSplitor = ["&", "\n"];
|
||||
const notify = $.isNode() ? require("./sendNotify") : "";
|
||||
const notify = $.isNode() ? require("../sendNotify") : "";
|
||||
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"
|
||||
|
||||
|
||||
@ -352,7 +352,7 @@ function _0x14a79b(_0x4038d3, _0x4c648e) {
|
||||
let _0x3d3a83 = this.name + " 运行通知\n\n" + this.notifyStr;
|
||||
if (_0x3065e9.isNode()) {
|
||||
{
|
||||
var _0x3a245e = require("./sendNotify");
|
||||
var _0x3a245e = require("../sendNotify");
|
||||
console.log("\n============== 推送 ==============");
|
||||
await _0x3a245e.sendNotify(this.name, _0x3d3a83);
|
||||
}
|
||||
|
||||
@ -433,7 +433,7 @@ function Env(_0x145f6d, _0x2ad434) {
|
||||
if (!this.notifyStr) return;
|
||||
let _0x49b71e = this.name + " 运行通知\n\n" + this.notifyStr;
|
||||
if ($.isNode()) {
|
||||
var _0x15c32f = require("./sendNotify");
|
||||
var _0x15c32f = require("../sendNotify");
|
||||
console.log("\n============== 推送 ==============");
|
||||
await _0x15c32f.sendNotify(this.name, _0x49b71e);
|
||||
} else this.msg(_0x49b71e);
|
||||
|
||||
@ -387,7 +387,7 @@ function Env(_0x513ce9, _0x3f5b80) {
|
||||
if (!this.notifyStr) return;
|
||||
let _0x44fa77 = this.name + " 运行通知\n\n" + this.notifyStr;
|
||||
if ($.isNode()) {
|
||||
var _0x2a2ac8 = require("./sendNotify");
|
||||
var _0x2a2ac8 = require("../sendNotify");
|
||||
console.log("\n============== 推送 ==============");
|
||||
await _0x2a2ac8.sendNotify(this.name, _0x44fa77);
|
||||
} else this.msg(_0x44fa77);
|
||||
|
||||
Loading…
Reference in New Issue
Block a user