mirror of
https://github.com/smallfawn/QLScriptPublic.git
synced 2026-01-12 04:20:43 +08:00
321 lines
11 KiB
JavaScript
321 lines
11 KiB
JavaScript
/*
|
||
------------------------------------------
|
||
@Author: sm
|
||
@Date: 2024.06.07 19:15
|
||
@Description: 测试
|
||
------------------------------------------
|
||
#Notice:
|
||
变量名jieshibang 抓小程序杰士邦会员中心https://api.vshop.hchiv.cn/jfmb/api Headers中 authorization 去掉Bearer 多账号&连接
|
||
⚠️【免责声明】
|
||
------------------------------------------
|
||
1、此脚本仅用于学习研究,不保证其合法性、准确性、有效性,请根据情况自行判断,本人对此不承担任何保证责任。
|
||
2、由于此脚本仅用于学习研究,您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除,若违反规定引起任何事件本人对此均不负责。
|
||
3、请勿将此脚本用于任何商业或非法目的,若违反规定请自行对此负责。
|
||
4、此脚本涉及应用与本人无关,本人对因此引起的任何隐私泄漏或其他后果不承担任何责任。
|
||
5、本人对任何脚本引发的问题概不负责,包括但不限于由脚本错误引起的任何损失和损害。
|
||
6、如果任何单位或个人认为此脚本可能涉嫌侵犯其权利,应及时通知并提供身份证明,所有权证明,我们将在收到认证文件确认后删除此脚本。
|
||
7、所有直接或间接使用、查看此脚本的人均应该仔细阅读此声明。本人保留随时更改或补充此声明的权利。一旦您使用或复制了此脚本,即视为您已接受此免责声明。
|
||
*/
|
||
|
||
const $ = new Env("杰士邦会员中心");
|
||
let ckName = `jieshibang`;
|
||
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"
|
||
|
||
class Public {
|
||
async request(options) {
|
||
return await axios.request(options);
|
||
}
|
||
}
|
||
class Task extends Public {
|
||
constructor(env) {
|
||
|
||
super();
|
||
this.index = $.userIdx++
|
||
let user = env.split("#");
|
||
this.token = user[0];
|
||
this.isSign = false;
|
||
}
|
||
async addSign() {
|
||
let options = {
|
||
method: "POST",
|
||
url: "https://api.vshop.hchiv.cn/jfmb/api/play-default/sign/add-sign-new.do?sideType=3&mob=&appId=wx5966681b4a895dee&shopNick=wx5966681b4a895dee×tamp=1739704494584&guideNo=&encryPlatId=d89385f4d1a7783414258f80d3fbedf6bb2d0e10f94fc010eb524fdd2a14f9a3",
|
||
headers: {
|
||
"accept": "*/*",
|
||
"accept-language": "zh-CN,zh;q=0.9",
|
||
"appenv": "test",
|
||
"authorization": "Bearer " + this.token,
|
||
"content-type": "application/json",
|
||
"sec-fetch-dest": "empty",
|
||
"sec-fetch-mode": "cors",
|
||
"sec-fetch-site": "cross-site",
|
||
"xweb_xhr": "1",
|
||
"cookie": "JSESSIONID=acb5cc02-db4e-4caf-9ebf-c5b67524ec06",
|
||
"Referer": "https://servicewechat.com/wx5966681b4a895dee/30/page-frame.html",
|
||
"Referrer-Policy": "unsafe-url"
|
||
},
|
||
data: JSON.stringify({
|
||
"appId": "wx5966681b4a895dee",
|
||
"openId": true,
|
||
"shopNick": "",
|
||
"timestamp": Date.now(),
|
||
"interfaceSource": 0,
|
||
"activityId": "156947"
|
||
}),
|
||
}
|
||
try {
|
||
let { data: res } = await this.request(options);
|
||
if (res.success == true) {
|
||
$.log(`签到成功 获得【${res.data.integral}】积分`)
|
||
} else {
|
||
$.log(`签到失败`)
|
||
console.log(res);
|
||
}
|
||
} catch (e) {
|
||
console.log(e);
|
||
|
||
}
|
||
}
|
||
async activityInfo() {
|
||
let options = {
|
||
method: "POST",
|
||
url: "https://api.vshop.hchiv.cn/jfmb/api/activity/activity-info.do?sideType=3&mob=&appId=wx5966681b4a895dee&shopNick=wx5966681b4a895dee×tamp=1739705505052&guideNo=&encryPlatId=d89385f4d1a7783414258f80d3fbedf6bb2d0e10f94fc010eb524fdd2a14f9a3",
|
||
headers: {
|
||
"accept": "*/*",
|
||
"accept-language": "zh-CN,zh;q=0.9",
|
||
"appenv": "test",
|
||
"authorization": "Bearer " + this.token,
|
||
"content-type": "application/json",
|
||
"sec-fetch-dest": "empty",
|
||
"sec-fetch-mode": "cors",
|
||
"sec-fetch-site": "cross-site",
|
||
"xweb_xhr": "1",
|
||
"cookie": "JSESSIONID=acb5cc02-db4e-4caf-9ebf-c5b67524ec06",
|
||
"Referer": "https://servicewechat.com/wx5966681b4a895dee/30/page-frame.html",
|
||
"Referrer-Policy": "unsafe-url"
|
||
},
|
||
data: JSON.stringify({
|
||
"appId": "wx5966681b4a895dee",
|
||
"openId": true,
|
||
"shopNick": "",
|
||
"timestamp": Date.now(),
|
||
"interfaceSource": 0,
|
||
"id": "156947"
|
||
}),
|
||
}
|
||
try {
|
||
let { data: res } = await this.request(options);
|
||
if (res.code == '1') {
|
||
|
||
if (res.data.isSign == false) {
|
||
$.log(`今日未签到`)
|
||
this.isSign = false
|
||
} else {
|
||
$.log(`今日已签到`)
|
||
this.isSign = true
|
||
}
|
||
} else {
|
||
|
||
}
|
||
} catch (e) {
|
||
console.log(e);
|
||
|
||
}
|
||
}
|
||
async run() {
|
||
|
||
await this.activityInfo();
|
||
if (this.isSign == false) {
|
||
await this.addSign();
|
||
}
|
||
|
||
|
||
}
|
||
|
||
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
!(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 new Public().request(options);
|
||
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 通知📣==============")
|
||
for (let i = 0; i < this.notifyStr.length; i++) {
|
||
if (Object.prototype.toString.call(this.notifyStr[i]) === '[object Object]' ||
|
||
Object.prototype.toString.call(this.notifyStr[i]) === '[object Array]') {
|
||
this.notifyStr[i] = JSON.stringify(this.notifyStr[i]);
|
||
}
|
||
}
|
||
|
||
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));
|
||
}
|
||
async done(t = {}) {
|
||
await 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);
|
||
} |