This commit is contained in:
smallfawn 2026-04-12 10:36:34 +08:00
parent a847364867
commit a95dcadf52
2 changed files with 196 additions and 2 deletions

View File

@ -28,7 +28,6 @@ const $ = new Env("臭宝乐园");
const WeChatCodeServer = require("wechat-mini-server");
let ckName = `choubaoleyuan`;
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"
let wechat = new WeChatCodeServer({
@ -209,7 +208,9 @@ class Task {
!(async () => {
await getNotice()
$.checkEnv(ckName);
if (process.env['wx_server_url'] && process.env['wx_auth']) {
$.userList = 'test'
}
for (let user of $.userList) {
await new Task(user).run();
}

193
wxTemp/tslj.js Normal file
View File

@ -0,0 +1,193 @@
/*
------------------------------------------
@Author: sm
@Date: 2024.06.07 19:15
@Description:
cron: 30 9 * * *
------------------------------------------
#Notice:
谢瑞麟 微信小程序 签到得积分
WeChatCodeServer 填写wx_server_url wx_auth 用于获取code
变量名称tslj
免责声明
------------------------------------------
1此脚本仅用于学习研究不保证其合法性准确性有效性请根据情况自行判断本人对此不承担任何保证责任
2由于此脚本仅用于学习研究您必须在下载后 24 小时内将所有内容从您的计算机或手机或任何存储设备中完全删除若违反规定引起任何事件本人对此均不负责
3请勿将此脚本用于任何商业或非法目的若违反规定请自行对此负责
4此脚本涉及应用与本人无关本人对因此引起的任何隐私泄漏或其他后果不承担任何责任
5本人对任何脚本引发的问题概不负责包括但不限于由脚本错误引起的任何损失和损害
6如果任何单位或个人认为此脚本可能涉嫌侵犯其权利应及时通知并提供身份证明所有权证明我们将在收到认证文件确认后删除此脚本
7所有直接或间接使用查看此脚本的人均应该仔细阅读此声明本人保留随时更改或补充此声明的权利一旦您使用或复制了此脚本即视为您已接受此免责声明
*/
const {
Env
} = require("../tools/env")
const $ = new Env("谢瑞麟小程序签到");
const WeChatCodeServer = require("wechat-mini-server");
let ckName = `tslj`;
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"
let wechat = new WeChatCodeServer({
url: process.env.wx_server_url || 'http://192.168.31.196:12081',
appid: 'wx439d0e0cc6742818',
auth: process.env.wx_auth || "your-api-key",
}
);
class Task {
constructor(env) {
this.index = $.userIdx++
this.user = env.split(strSplitor);
this.token = null
this.openid = null
this.isSign = false
}
async run() {
let { data: codeRes } = await wechat.GetMiniCode()
if (codeRes.status) {
await this.getUserToken(codeRes.data)
}
if (!this.token) {
$.log(`账号[${this.index}] 获取用户Token失败❌`)
return
}
this.token = 'Bearer ' + this.token
await this.getUserInfo()
if (!this.isSign) await this.doSign()
}
async getUserToken(code) {
let options = {
method: 'POST',
url: `https://tslmember-crm.tslj.com.cn/api/auth/login`,
headers: {
"accept": "*/*",
"accept-language": "zh-CN,zh;q=0.9",
"content-type": "application/json",
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/116.0.0.0 Safari/537.36 MicroMessenger/7.0.20.1781 NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF XWEB/50249"
}
,
data:
{ "code": code }
}
let {
data: result
} = await axios.request(options);
if (result?.code == '0') {
this.token = result.data.user_info.token
this.openid = result.data.user_info.openid
$.log(`🌸账号[${this.index}] 获取用户Token成功:${this.token}`)
} else {
$.log(`🌸账号[${this.index}] 获取用户Token-失败:${result.msg}`)
}
}
async getUserInfo() {
let options = {
method: 'POST',
url: `https://tslmember-crm.tslj.com.cn/api/user/index`,
headers: {
"accept": "*/*",
"accept-language": "zh-CN,zh;q=0.9",
"authorization": "" + this.token + "",
"content-type": "application/x-www-form-urlencoded",
"priority": "u=1, i",
"sec-fetch-dest": "empty",
"sec-fetch-mode": "cors",
"sec-fetch-site": "cross-site",
"user-agent": 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/132.0.0.0 Safari/537.36 MicroMessenger/7.0.20.1781(0x6700143B) NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF WindowsWechat(0x63090a13) UnifiedPCWindowsWechat(0xf254173b) XWEB/19027'
},
data: { "openid": this.openid }
}
let {
data: result
} = await axios.request(options);
if (result?.code == '0') {
//打印签到结果
$.log(`🌸账号[${this.index}]` + `[${result.data.mobile}] 积分[${result.data.integral}]🎉`);
for (let task of result.data.task_list) {
if (task.name == '每日签到') {
this.isSign = task.status
}
}
} else {
$.log(`🌸账号[${this.index}] 获取用户信息-失败:${result.msg}`)
}
}
async doSign() {
let options = {
method: 'POST',
url: `https://tslmember-crm.tslj.com.cn/api/userSignIn/signIn`,
headers: {
"accept": "*/*",
"accept-language": "zh-CN,zh;q=0.9",
"authorization": "" + this.token + "",
"content-type": "application/x-www-form-urlencoded",
"priority": "u=1, i",
"sec-fetch-dest": "empty",
"sec-fetch-mode": "cors",
"sec-fetch-site": "cross-site"
},
data: { "openid": `${this.openid}` }
};
let {
data: result
} = await axios.request(options);
if (result?.code == '0') {
//打印签到结果
const { integral, total_days } = result?.data;
$.log(`签到成功, 已连续签到 ${total_days} 天, 获得 ${integral} 积分 🎉`);
} else {
$.log(`🌸账号[${this.index}] 签到-失败:${result.msg}`)
}
}
}
!(async () => {
await getNotice()
$.checkEnv(ckName);
if (process.env['wx_server_url'] && process.env['wx_auth']) {
$.userList = 'test'
}
for (let user of $.userList) {
await new Task(user).run();
}
})()
.catch((e) => console.log(e))
.finally(() => $.done());
async function getNotice() {
try {
let options = {
url: `https://ghproxy.net/https://raw.githubusercontent.com/smallfawn/Note/refs/heads/main/Notice.json`,
headers: {
"User-Agent": defaultUserAgent,
},
timeout: 3000
}
let {
data: res
} = await axios.request(options);
$.log(res)
return res
} catch (e) { }
}