Учебное пособие по чтению сценария чтения Qinglong Wool WeChat, ежедневный доход 4 ~ 5 метров
Учебное пособие по чтению сценария чтения Qinglong Wool WeChat, ежедневный доход 4 ~ 5 метров

Те, кто умеет хватать сумки, будут смотреть, те, кто не умеет, будут смотреть.

Для чтения WeChat требуется среда Qinglong

Вход, откройте WeChat. -> Вход1:https://api.shanghaiqiye.top:10262/yunonline/v1/auth/080bb7730c1c22c0983b4c5755e84762?codeurl=shanghaiqiye.top:10262&codeuserid=2&time=1678618115

Вход2:https://api.caorenkj.top:10252/yunonline/v1/auth/080bb7730c1c22c0983b4c5755e84762?codeurl=caorenkj.top:10252&codeuserid=1&time=1678618115Домашняя страница захвата пакетов https://erd.jjt2019.top/yunonline/v1/gold?unionid=nonxxxx&time=1678449887000 в unionid

Захват пакетов для получения ссылок на статьи https://erd.jjt2019.top/yunonline/v1/task в теле запроса secret Заполните переменные jdyuedu , заполните метод unionid&secret Не используйте Unionid= и secret=, разделяйте несколько учетных записей переносами строк. Текущая статья о проверке неясна, но ее необходимо проверять в первом раунде каждый день, но проверка должна быть черной. Рекомендуется прочитать третью. статья в первом туре, и рекомендуется не бегать рано утром.

WeChat Чтение 2

Требуется среда Цинлун Вход, откройте WeChat. -> https://zl0104233736-1314804847.cos.ap-nanjing.myqcloud.com/index.html?upuid=10760102 Захватите файлы cookie под доменным именем m.*.work и заполните переменные среды. yuedu, несколько учетных записей будут проверяться примерно 2 раза в день, разделенные разрывами строк. Если вы встретите статью о проверке, вы можете открыть ее вручную и прочитать ее. В настоящее время 30 статей в день * 6 раундов по 180 статей стоят около 2,2 юаня.

Учебное пособие по чтению сценария чтения Qinglong Wool WeChat, ежедневный доход 4 ~ 5 метров

wx_yd.js

Язык кода:javascript
копировать
/*
Вичатчтение
Требуется среда Цинлун
Вход, откройте WeChat. -> https://zl0104233736-1314804847.cos.ap-nanjing.myqcloud.com/index.html?upuid=10760102
Захватите файлы cookie под доменным именем m.*.work и заполните переменные среды. yuedu, несколько учетных записей, разделенных разрывами строк
 
Он будет проверяться примерно 2 раза в день. Когда вы встретите проверочную статью, просто откройте ее вручную и прочитайте.
В настоящее время 30 статей в день * 6 раундов по 180 статей стоят около 2,2 юаня.
Наличные будут сняты автоматически
*/
 
const $ = new Env("Вичатчтение");
const notify = $.isNode() ? require('./sendNotify') : '';
let envSplitor = ['@', '\n']
let httpResult, httpReq, httpResp
let ckName = 'yuedu'
let userCookie = ($.isNode() ? process.env[ckName] : $.getdata(ckName)) || '';
let userList = []
let userIdx = 0
let userCount = 0
var msg = ''
let newurl = "http://m.xmrygnuv.shop"
///////////////////////////////////////////////////////////////////
class UserInfo {
    constructor(str) {
        //console.log(str)
        this.index = ++userIdx, this.idx = `Аккаунт[${this.index}] `, this.ck = str//.split('#'), this.u = this.ck[0], this.t = this.ck[1]
    }
 
    async getreadurl() {
        try {
            let t = Date.now()
            this.ul = newurl+`/tuijian/do_read?for\u003d\u0026zs\u003d\u0026pageshow\u0026r\u003d0.016638941704032684`;
            let body = ``;
            let urlObject = popu(this.ul, body,this.ck)
            await httpRequest('get', urlObject)
            let result = httpResult;
            //console.log(result)
            if ( result.jkey && result.url) {
                this.jkey=result.jkey
                await this.read(result.url.split('redirect_uri=')[1])
            }
            /*
            "1" == result.info.type && 1 !== this.dx && (console.log(`Статья получена успешно `), this.b = 1, await $.wait(1000), await this.readfinish()),
                "3" == result.info.type && 1 !== this.dx && (console.log(`Чтение ограничено   Пробовал проверку`), this.x = result.info.key, this.c = result.info.url.split("/s/")[1], this.b = 2,
                    await $.wait(6000), await this.readfinish());
                    */
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
 
    async read(readurl) {
        try {
            let t = Date.now()
            readurl = decodeURIComponent(readurl);
            var sj = Math.random() * (8000 - 6000) + 6000
 
            if (readurl.indexOf("jump")==-1){
 
                console.log("Статья о подозрении на обнаружение, не прочитана")
 
                await $.wait(sj)
                return
                await this.readfinish()
                 
 
            }
            this.jumpid = readurl.match(/jumpid=(.*?)&/)[1]
            this.state= readurl.match(/state=(.*?)&/)[1]
            this.ul = newurl+`/fast_reada/oiejr?jumpid=${this.jumpid}&code=031oV60w32RVa03URy0w3E0mzj3oV607&state=` + this.state
            //console.log(this.ul)
             
            let body = ``;
            let urlObject = popu(this.ul, body,this.ck)
            await httpRequest('get', urlObject)
            let result = httpResult;
            //console.log(result)
            //var sj = Math.random() * (8000 - 6000) + 6000
            //console.log('Ожидание:'+ sj)
            await $.wait(sj)
            await this.readfinish()
             
            /*
            "1" == result.info.type && 1 !== this.dx && (console.log(`Статья получена успешно `), this.b = 1, await $.wait(1000), await this.readfinish()),
                "3" == result.info.type && 1 !== this.dx && (console.log(`Чтение ограничено   Пробовал проверку`), this.x = result.info.key, this.c = result.info.url.split("/s/")[1], this.b = 2,
                    await $.wait(6000), await this.readfinish());
                    */
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async readfinish() {
        try {
 
            this.url=newurl+'/tuijian/do_read?for=&zs=&pageshow=&r=0.7882316111246435&jkey='+this.jkey
            let body = ``;
            let urlObject = popu(this.url, body,this.ck)
            //console.log(urlObject)
            await httpRequest('get', urlObject)
            let result = httpResult;
            if (result && result.success_msg) {
                console.log(result.success_msg)
            } else {
                console.log(result)
            }
             
            /*
            "success" == result.msg && console.log(`Увеличение золотых монет-> ${result.info.num} Время чтения ${result.info.read_num} Текущие золотые монеты ${result.info.read_money}`),
                result.code > 200 && (console.log(`Достигнут объем чтения Жду обновления`), this.fx = 1);
                */
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async getreadinfo() {
        try {
            let t = Date.now()
            let url = newurl+`/tuijian`;
            let body = ``;
            let urlObject = popu(url, body,this.ck)
            //console.log()
            await httpRequest('get', urlObject)
            let result = httpResult;
            //console.log(result)
             
 
            if (result && result.data) {
                result = result.data
                this.uid = result.user.uid
                console.log(`\nСегодняшний счетчик/доход: ${result.infoView.num}/${result.infoView.score} очков \n`)
                console.log(`\nТекущий баланс: ${result.user.score} очков  \n`)
                this.cishu = result.infoView.rest
                 
                if (result.infoView.status != 1) {
                    this.fb = 1
                }
                if (result.infoView.status == 3) {
                   // console.log(result.infoView.msg)
                    msg += ''
                    console.log('Чтобы обнаружить статьи, вам нужно сделать это вручную')
                    msg += `\n${this.idx} Статья об обнаружении встреч\n`
                    this.fb = 1
                  
                } else if (result.infoView.status == 4) {
                    console.log(result.infoView.msg)
 
                } else if (result.infoView.rest == 0){
                    console.log(result.infoView.msg)
                }
            }
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
 
 
    async withdrawal() {
        try {
            let t = Date.now()
            let url = newurl+`/withdrawal`;
            let body = ``;
            let urlObject = popu(url, body,this.ck)
            await httpRequest('get', urlObject)
            let result = httpResult;
            if (result.data.user) {
                result = result.data.user
                console.log(`\nТекущий баланс счета ${result.score} минут \n`)
                if (this.ck.indexOf('##') != -1) return
                this.f = parseInt(result.score)//= Number(Math.floor(result.info.sum / 1000))
                /*
                if (this.f < 3) console.log(`\n Не удовлетворен 0,3 Порог вывода средств\n`)
                this.f >= 3 && this.f < 5 && (this.cash = .3), this.f >= 10 && this.f < 20 && (this.cash = 1), this.f >= 20 && this.f < 50 && (this.cash = 2),
                    this.f >= 50 && this.f < 100 && (this.cash = 2), this.f >= 100 && this.f < 200 && (this.cash = 10), this.f >= 200 && (this.cash = 20)
                if (this.f >= 3) console.log(`\nМожно снять наличные ${result.info.sum}золотые монеты Перейти к снятию наличных ${this.cash} юаней\n`), await this.exchange()
                */
                if (this.f < 30) {
                    console.log(`не удовлетворено Порог вывода`)
                } else {
                    console.log(`Перейти к снятию наличных${this.f/100}Юань。。。。。。`)
                    await this.doWithdraw(this.f)
                }
            }
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async doWithdraw(tx) {
        try {
            if (tx > 2000) tx = 2000
            let t = Date.now()
            let url = newurl+`/withdrawal/doWithdraw`;
            let body = `amount=` + tx;
            let urlObject = popu(url, body,this.ck)
            await httpRequest('post', urlObject)
            let result = httpResult;
            console.log(result)
 
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async task() {
        try {
             
            let abc = [...new Array(15).keys()]
            console.log(`\n=========== ${this.idx} Начать читать статью ===========\n`)
            await this.getreadinfo()
            //console.log(this.fb)
            if (this.fb != 1) {
                for (let i = 0;i< this.cishu;i++) {
                    await this.getreadurl()
 
                    /*
                    break
                    if (this.dx == 1) break
                    await this.getreadurl()
                    if (this.fx == 1) break
                    */
                }
                await this.getreadinfo()
                //await $.wait(15000)
                 
            }
            await this.withdrawal()
             
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
}
 
!(async () => {
    if (typeof $request !== "undefined") {
        await GetRewrite()
    } else {
        if (!(await checkEnv())) return;
        if (userList.length > 0) {
            await gethost()
            console.log('Получить новый URL:'+newurl)
            for (let user of userList) {
                await user.task()
            }
            if (msg) await notify.sendNotify('Вичатчтение обнаружить статью',msg)
        }
    }
})()
    .catch((e) => console.log(e))
    .finally(() => $.done())
 
///////////////////////////////////////////////////////////////////
 
async function gethost() {
    try {
        let t = Date.now()
        let url = 'https://qun.haozhuang.cn.com/fq_url/rk';
        let body = ''
        let urlObject = popugethost(url, body)
        await httpRequest('get', urlObject)
        let result = httpResult;
        //console.log(result)
        if (result.jump) {
            newurl = result.jump.slice(0,-1)
 
        }
    } catch (e) {
        console.log(e)
    } finally {
        return Promise.resolve(1);
    }
}
 
async function checkEnv() {
    if (userCookie) {
        let splitor = envSplitor[0];
        for (let sp of envSplitor) {
            if (userCookie.indexOf(sp) > -1) {
                splitor = sp;
                break;
            }
        }
        for (let userCookies of userCookie.split(splitor)) {
            if (userCookies)
                userList.push(new UserInfo(userCookies))
 
        }
        userCount = userList.length
    } else {
    }
 
    console.log(`Найдено [${ckName}] переменная ${userCount}аккаунты`)
 
 
 
    return true
}
 
////////////////////////////////////////////////////////////////////
function popu(url, body = '',ck) {
    //console.log(ck) /?upuid\u003d10314864
    let host = url.replace('//', '/').split('/')[1]
    let urlObject = {
        url: url,
        headers: {
            "Host": host,
            "Connection": "keep-alive",
            "Accept": "*/*",
            "User-Agent": "Mozilla/5.0 (Linux; Android 12; M2012K11AC Build/SKQ1.211006.001; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/86.0.4240.99 XWEB/4425 MMWEBSDK/20221206 Mobile Safari/537.36 MMWEBID/4883 MicroMessenger/8.0.32.2300(0x2800205D) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64",
            "X-Requested-With": "com.tencent.mm",
            "Referer": newurl+"/tuijian/read",
            "Accept-Encoding": "gzip, deflate",
            "Accept-Language": "zh-CN,zh;q\u003d0.9,en-US;q\u003d0.8,en;q\u003d0.7",
            "Cookie": ck,
        },
        timeout: 5000,
    }
    if (body) {
        urlObject.body = body
    }
 
    return urlObject;
}
function popugethost(url, body = '',ck) {
    //console.log(ck)
    let host = url.replace('//', '/').split('/')[1]
    let urlObject = {
        url: url,
        headers:   {
            "Host": "qun.haozhuang.cn.com",
            "User-Agent": "Mozilla/5.0 (Linux; Android 12; M2012K11AC Build/SKQ1.211006.001; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/86.0.4240.99 XWEB/4425 MMWEBSDK/20221206 Mobile Safari/537.36 MMWEBID/4883 MicroMessenger/8.0.32.2300(0x2800205D) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64",
            "Accept": "*/*",
            "Origin": "https://kygj0209122405-1316151879.cos.ap-nanjing.myqcloud.com",
            "X-Requested-With": "com.tencent.mm",
            "Referer": "https://kygj0209122405-1316151879.cos.ap-nanjing.myqcloud.com/index.html?upuid\u003d10315076"
        },
        timeout: 5000,
    }
    if (body) {
        urlObject.body = body
    }
 
    return urlObject;
}
 
async function httpRequest(method, url) {
    //console.log(url)
    httpResult = null, httpReq = null, httpResp = null;
    return new Promise((resolve) => {
        $.send(method, url, async (err, req, resp) => {
            try {
                httpReq = req;
                httpResp = resp;
                if (err) {
                } else {
                    if (resp.body) {
                        if (typeof resp.body == "object") {
                            httpResult = resp.body;
                        } else {
                            try {
                                httpResult = JSON.parse(resp.body);
                            } catch (e) {
                                httpResult = resp.body;
                            }
                        }
                    }
                }
            } catch (e) {
                console.log(e);
            } finally {
                resolve();
            }
        });
    });
}
////////////////////////////////////////////////////////////////////
function Env(a, b) {
    return "undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0), new class {
        constructor(a, b) {
            this.name = a, this.notifyStr = "", this.startTime = (new Date).getTime(), Object.assign(this, b), console.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 } getdata(b) { let a = this.getval(b); if (/^@/.test(b)) { let [, c, f] = /^@(.*?)\.(.*?)$/.exec(b), d = c ? this.getval(c) : ""; if (d) try { let e = JSON.parse(d); a = e ? this.lodash_get(e, f, "") : a } catch (g) { a = "" } } return a } setdata(c, d) { let a = !1; if (/^@/.test(d)) { let [, b, e] = /^@(.*?)\.(.*?)$/.exec(d), f = this.getval(b), i = b ? "null" === f ? null : f || "{}" : "{}"; try { let g = JSON.parse(i); this.lodash_set(g, e, c), a = this.setval(JSON.stringify(g), b) } catch (j) { let h = {}; this.lodash_set(h, e, c), a = this.setval(JSON.stringify(h), b) } } else a = this.setval(c, d); return a } getval(a) { return this.isSurge() || this.isLoon() ? $persistentStore.read(a) : this.isQuanX() ? $prefs.valueForKey(a) : this.isNode() ? (this.data = this.loaddata(), this.data[a]) : this.data && this.data[a] || null } setval(b, a) { return this.isSurge() || this.isLoon() ? $persistentStore.write(b, a) : this.isQuanX() ? $prefs.setValueForKey(b, a) : this.isNode() ? (this.data = this.loaddata(), this.data[a] = b, this.writedata(), !0) : this.data && this.data[a] || null } send(b, a, f = () => { }) { if ("get" != b && "post" != b && "put" != b && "delete" != b) { console.log(`Неверный http-метод: ${b}`); return } if ("get" == b && a.headers ? (delete a.headers["Content-Type"], delete a.headers["Content-Length"]) : a.body && a.headers && (a.headers["Content-Type"] || (a.headers["Content-Type"] = "application/x-www-form-urlencoded")), this.isSurge() || this.isLoon()) { this.isSurge() && this.isNeedRewrite && (a.headers = a.headers || {}, Object.assign(a.headers, { "X-Surge-Skip-Scripting": !1 })); let c = { method: b, url: a.url, headers: a.headers, timeout: a.timeout, data: a.body }; "get" == b && delete c.data, $axios(c).then(a => { let { status: b, request: c, headers: d, data: e } = a; f(null, c, { statusCode: b, headers: d, body: e }) }).catch(a => console.log(a)) } else if (this.isQuanX()) a.method = b.toUpperCase(), this.isNeedRewrite && (a.opts = a.opts || {}, Object.assign(a.opts, { hints: !1 })), $task.fetch(a).then(a => { let { statusCode: b, request: c, headers: d, body: e } = a; f(null, c, { statusCode: b, headers: d, body: e }) }, a => f(a)); else if (this.isNode()) { this.got = this.got ? this.got : require("got"); let { url: d, ...e } = a; this.instance = this.got.extend({ followRedirect: !1 }), this.instance[b](d, e).then(a => { let { statusCode: b, request: c, headers: d, body: e } = a; f(null, c, { statusCode: b, headers: d, body: e }) }, b => { let { message: c, response: a } = b; f(c, a, a && a.body) }) } } time(a) { let b = { "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() }; for (let c in /(y+)/.test(a) && (a = a.replace(RegExp.$1, ((new Date).getFullYear() + "").substr(4 - RegExp.$1.length))), b) new RegExp("(" + c + ")").test(a) && (a = a.replace(RegExp.$1, 1 == RegExp.$1.length ? b[c] : ("00" + b[c]).substr(("" + b[c]).length))); return a } async showmsg() { if (!this.notifyStr) return; let a = this.name + " \u8FD0\u884C\u901A\u77E5\n\n" + this.notifyStr; if ($.isNode()) { var b = require("./sendNotify"); console.log("\n============== \u63A8\u9001 =============="), await b.sendNotify(this.name, a) } else this.msg(a) } logAndNotify(a) { console.log(a), this.notifyStr += a, this.notifyStr += "\n" } msg(d = t, a = "", b = "", e) { let f = a => { if (!a) return a; if ("string" == typeof a) return this.isLoon() ? a : this.isQuanX() ? { "open-url": a } : this.isSurge() ? { url: a } : void 0; if ("object" == typeof a) { if (this.isLoon()) { let b = a.openUrl || a.url || a["open-url"], c = a.mediaUrl || a["media-url"]; return { openUrl: b, mediaUrl: c } } if (this.isQuanX()) { let d = a["open-url"] || a.url || a.openUrl, e = a["media-url"] || a.mediaUrl; return { "open-url": d, "media-url": e } } if (this.isSurge()) return { url: a.url || a.openUrl || a["open-url"] } } }; this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(d, a, b, f(e)) : this.isQuanX() && $notify(d, a, b, f(e))); let c = ["", "============== \u7CFB\u7EDF\u901A\u77E5 =============="]; c.push(d), a && c.push(a), b && c.push(b), console.log(c.join("\n")) } getMin(a, b) { return a < b ? a : b } getMax(a, b) { return a < b ? b : a } padStr(e, b, f = "0") { let a = String(e), g = b > a.length ? b - a.length : 0, c = ""; for (let d = 0; d < g; d++)c += f; return c + a } json2str(b, e, f = !1) { let c = []; for (let d of Object.keys(b).sort()) { let a = b[d]; a && f && (a = encodeURIComponent(a)), c.push(d + "=" + a) } return c.join(e) } str2json(e, f = !1) { let d = {}; for (let a of e.split("#")) { if (!a) continue; let b = a.indexOf("="); if (-1 == b) continue; let g = a.substr(0, b), c = a.substr(b + 1); f && (c = decodeURIComponent(c)), d[g] = c } return d } randomString(d, a = "abcdef0123456789") { let b = ""; for (let c = 0; c < d; c++)b += a.charAt(Math.floor(Math.random() * a.length)); return b } randomList(a) { let b = Math.floor(Math.random() * a.length); return a[b] } wait(a) { return new Promise(b => setTimeout(b, a)) } done(a = {}) {
*/
            let b = (new Date).getTime(), c = (b - this.startTime) / 1e3; console.log(`
${this.name} Операция завершена, и всего ${c} Второй! `), (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(a)
        }
    }(a, b)
}
Язык кода:javascript
копировать
/*
Вичатчтение
Требуется среда Цинлун
Вход, откройте WeChat. -> Вход1:https://api.shanghaiqiye.top:10262/yunonline/v1/auth/080bb7730c1c22c0983b4c5755e84762?codeurl=shanghaiqiye.top:10262&codeuserid=2&time=1678618115
Вход2:https://api.caorenkj.top:10252/yunonline/v1/auth/080bb7730c1c22c0983b4c5755e84762?codeurl=caorenkj.top:10252&codeuserid=1&time=1678618115
 
Домашняя страница захвата пакетов https://erd.jjt2019.top/yunonline/v1/gold?unionid=nonxxxx&time=1678449887000 в unionid
Захват пакетов для получения ссылок на статьи https://erd.jjt2019.top/yunonline/v1/task в теле запроса secret 
Заполните переменные jdyuedu , заполните метод unionid&secret Не используйте unionid= и secret=, разделяйте несколько учетных записей символами новой строки.
 
Статья о проверке на данный момент неясна, но ее необходимо проверять в первом раунде каждый день, но проверка должна быть черной. Рекомендуется прочитать третью статью в первом раунде, и не рекомендуется запускать ее раньше. утро.
 
Обновление 3.12: первые 2 статьи, а также статьи 101 и 102 были изменены на статьи обнаружения. Если вы столкнулись с нечитаемыми статьями, прочитайте их вручную.
 
*/
 
const $ = new Env("Вичат Простое Чтение");
const notify = $.isNode() ? require('./sendNotify') : '';
let envSplitor = ['@', '\n']
let httpResult, httpReq, httpResp
let ckName = 'jdyuedu'
let userCookie = ($.isNode() ? process.env[ckName] : $.getdata(ckName)) || '';
let userList = []
let userIdx = 0
let userCount = 0
var msg = ''
var jiance = 0 //1Получить статью , 0 читает
let newurl = "https://erd.jjt2019.top:10267"
///////////////////////////////////////////////////////////////////
class UserInfo {
    constructor(str) {
        //console.log(str)
        this.istx = 1
        if (str.indexOf('##')!=-1) this.istx=0
        this.index = ++userIdx, this.idx = `Аккаунт[${this.index}] `, this.unionid = str.split('&')[0], this.secret = str.split('&')[1]//.split('#'), this.u = this.ck[0], this.t = this.ck[1]
    }
 
    async dotask() {
        try {
            let t = Date.now()
            this.ul = newurl+`/yunonline/v1/task`;
            let body = 'secret='+this.secret+'&type=read';
            let urlObject = popu(this.ul, body,this.unionid)
            await httpRequest('post', urlObject)
            let result = httpResult;
            //console.log(result)
            if ( result.msg == 'success') {
                if (jiance == 1) {
                    console.log( result.data.link)
                    msg += '\n' + result.data.link + '\n'
                } else {
                    await this.jump(result.data.link.split('redirect_uri=')[1])
                }
                 
                 
            } else if (result.errcode == 409){
                console.log('Следующее время чтения:', result.msg/60,'минуты спустя')
 
            } else if (result.errcode == 407){
                console.log(result.msg)
            } else {
                console.log(result)
            }
            /*
            "1" == result.info.type && 1 !== this.dx && (console.log(`Статья получена успешно `), this.b = 1, await $.wait(1000), await this.readfinish()),
                "3" == result.info.type && 1 !== this.dx && (console.log(`Чтение ограничено   Пробовал проверку`), this.x = result.info.key, this.c = result.info.url.split("/s/")[1], this.b = 2,
                    await $.wait(6000), await this.readfinish());
                    */
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
 
    async jump(readurl) {
        try {
            let t = Date.now()
            readurl = decodeURIComponent(readurl);
            var sj = Math.random() * (7000 - 6000) + 4000
             
             
            this.key = readurl.match(/key=(.*?)&/)[1]
            this.state= readurl.match(/state=(.*?)#/)[1]
            this.ul = newurl+`/yunonline/v1/jump?key=${this.key}&unionid=${this.unionid}&code=071jHI0w3wTxf03NIp1w36OkoF1jHI0P&state=` + this.state
            //console.log(readurl)
             
            let body = ``;
            let urlObject = popu(this.ul, body,this.unionid)
            await httpRequest('get', urlObject)
            let result = httpResult;
            //console.log(result)
            //var sj = Math.random() * (8000 - 6000) + 6000
            //console.log('Ожидание:'+ sj)
            await $.wait(sj)
            await this.add_gold()
             
            /*
            "1" == result.info.type && 1 !== this.dx && (console.log(`Статья получена успешно `), this.b = 1, await $.wait(1000), await this.readfinish()),
                "3" == result.info.type && 1 !== this.dx && (console.log(`Чтение ограничено   Пробовал проверку`), this.x = result.info.key, this.c = result.info.url.split("/s/")[1], this.b = 2,
                    await $.wait(6000), await this.readfinish());
                    */
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async add_gold() {
        try {
             var sj = Math.random() * (7000 - 6000) + 1000
            this.url=newurl+'/yunonline/v1/add_gold'
            let body = 'unionid=' + this.unionid + '&time=7';
            let urlObject = popu(this.url, body,this.unionid)
            //console.log(urlObject)
            await httpRequest('post', urlObject)
            let result = httpResult;
            if (result && result.data) {
                console.log('получить',result.data.gold,'золотые монеты')
                if (result.data.day_read == 100 || result.data.day_read == 101 ) {
                    console.log('Это может быть статья об обнаружении, пожалуйста, прочитайте 2–3 статьи вручную')
                    msg += `\n======== счет ${this.idx} Вы можете встретить статьи по обнаружению ========\n`
                    msg += '\nПожалуйста, прочитайте первые две статьи вручную\n'
                } else{
                    await $.wait(sj)
                    await this.dotask()
                }
                 
 
            } else {
                console.log(result)
            }
             
            /*
            "success" == result.msg && console.log(`Увеличение золотых монет-> ${result.info.num} Время чтения ${result.info.read_num} Текущие золотые монеты ${result.info.read_money}`),
                result.code > 200 && (console.log(`Достигнут объем чтения Жду обновления`), this.fx = 1);
                */
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async gold() {
        try {
            let t = Date.now()
            let url = newurl+`/yunonline/v1/gold?unionid=${this.unionid}&time=`+t;
            let body = ``;
            let urlObject = popu(url, body,this.unionid)
            //console.log(urlObject)
            await httpRequest('get', urlObject)
            let result = httpResult;
            //console.log(result)
             
 
            if (result && result.data) {
                result = result.data
 
                console.log(`\nСегодняшнее количество/доход от чтения: ${result.day_read}/${result.day_gold}золотых монет `)
                console.log(`Текущий баланс: ${result.last_gold}золотые монеты  `)
                this.fb = 1
                this.left_gold=result.last_gold
                if (result.day_read == 0 || result.day_read == 1) {
                    console.log('Пожалуйста, прочитайте первые две статьи вручную')
                    this.fb = 0
                    msg += `\n======== счет ${this.idx} Вы можете встретить статьи по обнаружению ========\n`
                    msg += '\nПожалуйста, прочитайте первые две статьи вручную\n'
 
                } else if (result.day_read == 100 || result.day_read == 101) {
                    console.log('101 и 102 могут быть статьями обнаружения, пожалуйста, прочитайте их вручную')
                    this.fb=0
                    msg += `\n======== счет ${this.idx} Вы можете встретить статьи по обнаружению ========\n`
                    msg += '\nПожалуйста, прочитайте первые две статьи вручную\n'
                }
                /*
                this.cishu = result.infoView.rest
                 
                if (result.infoView.status != 1) {
                    this.fb = 1
                }
                if (result.infoView.status == 3) {
                   // console.log(result.infoView.msg)
                    msg += ''
                    console.log('Чтобы обнаружить статьи, вам нужно сделать это вручную')
                    msg += `\n${this.idx} Статья об обнаружении встреч\n`
                    this.fb = 1
                  
                } else if (result.infoView.status == 4) {
                    console.log(result.infoView.msg)
 
                } else if (result.infoView.rest == 0){
                    console.log(result.infoView.msg)
                }
                */
            }
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
 
 
    async withdrawal() {
        try {
            let t = Date.now()
            let url = newurl+`/yunonline/v1/user_gold`;
            let body = `unionid=${this.unionid}&request_id=4c33a60c5f1068b83e576ca806bd4b6b&gold=1000`;
            let urlObject = popu(url, body,this.unionid)
            await httpRequest('post', urlObject)
            let result = httpResult;
            if (result.msg=='success') {
                result = result.data
                console.log(`\nПреобразовать для получения баланса ${result.money}юань \n`)
                if (result.money >= 0.3) {
                    await this.doWithdraw()
                }
                /*
                if (this.f < 3) console.log(`\n Не удовлетворен 0,3 Порог вывода средств\n`)
                this.f >= 3 && this.f < 5 && (this.cash = .3), this.f >= 10 && this.f < 20 && (this.cash = 1), this.f >= 20 && this.f < 50 && (this.cash = 2),
                    this.f >= 50 && this.f < 100 && (this.cash = 2), this.f >= 100 && this.f < 200 && (this.cash = 10), this.f >= 200 && (this.cash = 20)
                if (this.f >= 3) console.log(`\nМожно снять наличные ${result.info.sum}золотые монеты Перейти к снятию наличных ${this.cash} юаней\n`), await this.exchange()
                */
 
            }else{
                console.log(result)
            }
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async doWithdraw(tx) {
        try {
 
            let t = Date.now()
            let url = newurl+`/yunonline/v1/withdraw`;
            let body =  `unionid=${this.unionid}&request_id=4c33a60c5f1068b83e576ca806bd4b6b&ua=2`;
            let urlObject = popu(url, body,this.unionid)
            await httpRequest('post', urlObject)
            let result = httpResult;
            console.log(result)
 
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
    async task() {
        try {
             
            let abc = [...new Array(15).keys()]
             
            console.log(`\n=========== ${this.idx} Начать читать статью ===========\n`)
            await this.gold()
             
            //console.log(this.fb)
            if (this.fb == 1) {
                await this.dotask()
                await this.gold()
                //await $.wait(15000)
                 
            }
            if (this.left_gold >= 3000 && this.istx == 1) await this.withdrawal()
             
        } catch (e) {
            console.log(e)
        } finally {
            return Promise.resolve(1);
        }
    }
}
 
!(async () => {
    if (typeof $request !== "undefined") {
        await GetRewrite()
    } else {
        if (!(await checkEnv())) return;
        if (userList.length > 0) {
            //await gethost()
            //console.log('Получить новый URL:'+newurl)
            for (let user of userList) {
                await user.task()
            }
            if (msg.indexOf('Пожалуйста, прочитайте вручную') !=-1) await notify.sendNotify('Вичатчтение обнаружить статью',msg)
        }
    }
})()
    .catch((e) => console.log(e))
    .finally(() => $.done())
 
///////////////////////////////////////////////////////////////////
 
async function gethost() {
    try {
        let t = Date.now()
        let url = 'https://qun.haozhuang.cn.com/fq_url/rk';
        let body = ''
        let urlObject = popugethost(url, body)
        await httpRequest('get', urlObject)
        let result = httpResult;
        //console.log(result)
        if (result.jump) {
            newurl = result.jump.slice(0,-1)
 
        }
    } catch (e) {
        console.log(e)
    } finally {
        return Promise.resolve(1);
    }
}
 
async function checkEnv() {
    if (userCookie) {
        let splitor = envSplitor[0];
        for (let sp of envSplitor) {
            if (userCookie.indexOf(sp) > -1) {
                splitor = sp;
                break;
            }
        }
        for (let userCookies of userCookie.split(splitor)) {
            if (userCookies)
                userList.push(new UserInfo(userCookies))
 
        }
        userCount = userList.length
    } else {
    }
 
    console.log(`Найдено [${ckName}] переменная ${userCount}аккаунты`)
 
 
 
    return true
}
 
////////////////////////////////////////////////////////////////////
function popu(url, body = '',ck) {
    //console.log(ck) /?upuid\u003d10314864
    let host = url.replace('//', '/').split('/')[1]
    let urlObject = {
        url: url,
        headers:  {
            "Host": "erd.jjt2019.top:10267",
            //"content-length": "50",
            "accept": "application/json, text/javascript, */*; q\u003d0.01",
            "x-requested-with": "XMLHttpRequest",
            "user-agent": "Mozilla/5.0 (Linux; Android 12; M2012K11AC Build/SKQ1.211006.001; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/86.0.4240.99 XWEB/5019 MMWEBSDK/20221206 Mobile Safari/537.36 MMWEBID/3684 MicroMessenger/8.0.32.2300(0x2800205D) WeChat/arm64 Weixin NetType/5G Language/zh_CN ABI/arm64",
            "content-type": "application/x-www-form-urlencoded; charset\u003dUTF-8",
            //"origin": "https://erd.jjt2019.top:10267",
            "sec-fetch-site": "same-origin",
            "sec-fetch-mode": "cors",
            "sec-fetch-dest": "empty",
            "referer": "https://erd.jjt2019.top:10267/yunonline/v8623/redirect/156db1c3b5dd01c24254aa07a793ff15?openid\u003doUDcn6KK6c8bQ1VAVgD8PAX0OqEE\u0026unionid\u003d"+ck,
            "accept-encoding": "gzip, deflate",
            "accept-language": "zh-CN,zh;q\u003d0.9,en-US;q\u003d0.8,en;q\u003d0.7"
        },
        timeout: 5000,
    }
    if (body) {
        urlObject.body = body
        urlObject.headers['content-length'] = body.length
    }
 
    return urlObject;
}
function popugethost(url, body = '',ck) {
    //console.log(ck)
    let host = url.replace('//', '/').split('/')[1]
    let urlObject = {
        url: url,
        headers:   {
            "Host": "qun.haozhuang.cn.com",
            "User-Agent": "Mozilla/5.0 (Linux; Android 12; M2012K11AC Build/SKQ1.211006.001; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/86.0.4240.99 XWEB/4425 MMWEBSDK/20221206 Mobile Safari/537.36 MMWEBID/4883 MicroMessenger/8.0.32.2300(0x2800205D) WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64",
            "Accept": "*/*",
            "Origin": "https://kygj0209122405-1316151879.cos.ap-nanjing.myqcloud.com",
            "X-Requested-With": "com.tencent.mm",
            "Referer": "https://kygj0209122405-1316151879.cos.ap-nanjing.myqcloud.com/index.html?upuid\u003d10315076"
        },
        timeout: 5000,
    }
    if (body) {
        urlObject.body = body
    }
 
    return urlObject;
}
 
async function httpRequest(method, url) {
    //console.log(url)
    httpResult = null, httpReq = null, httpResp = null;
    return new Promise((resolve) => {
        $.send(method, url, async (err, req, resp) => {
            try {
                httpReq = req;
                httpResp = resp;
                if (err) {
                } else {
                    if (resp.body) {
                        if (typeof resp.body == "object") {
                            httpResult = resp.body;
                        } else {
                            try {
                                httpResult = JSON.parse(resp.body);
                            } catch (e) {
                                httpResult = resp.body;
                            }
                        }
                    }
                }
            } catch (e) {
                console.log(e);
            } finally {
                resolve();
            }
        });
    });
}
////////////////////////////////////////////////////////////////////
function Env(a, b) {
    return "undefined" != typeof process && JSON.stringify(process.env).indexOf("GITHUB") > -1 && process.exit(0), new class {
        constructor(a, b) {
            this.name = a, this.notifyStr = "", this.startTime = (new Date).getTime(), Object.assign(this, b), console.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 } getdata(b) { let a = this.getval(b); if (/^@/.test(b)) { let [, c, f] = /^@(.*?)\.(.*?)$/.exec(b), d = c ? this.getval(c) : ""; if (d) try { let e = JSON.parse(d); a = e ? this.lodash_get(e, f, "") : a } catch (g) { a = "" } } return a } setdata(c, d) { let a = !1; if (/^@/.test(d)) { let [, b, e] = /^@(.*?)\.(.*?)$/.exec(d), f = this.getval(b), i = b ? "null" === f ? null : f || "{}" : "{}"; try { let g = JSON.parse(i); this.lodash_set(g, e, c), a = this.setval(JSON.stringify(g), b) } catch (j) { let h = {}; this.lodash_set(h, e, c), a = this.setval(JSON.stringify(h), b) } } else a = this.setval(c, d); return a } getval(a) { return this.isSurge() || this.isLoon() ? $persistentStore.read(a) : this.isQuanX() ? $prefs.valueForKey(a) : this.isNode() ? (this.data = this.loaddata(), this.data[a]) : this.data && this.data[a] || null } setval(b, a) { return this.isSurge() || this.isLoon() ? $persistentStore.write(b, a) : this.isQuanX() ? $prefs.setValueForKey(b, a) : this.isNode() ? (this.data = this.loaddata(), this.data[a] = b, this.writedata(), !0) : this.data && this.data[a] || null } send(b, a, f = () => { }) { if ("get" != b && "post" != b && "put" != b && "delete" != b) { console.log(`Неверный http-метод: ${b}`); return } if ("get" == b && a.headers ? (delete a.headers["Content-Type"], delete a.headers["Content-Length"]) : a.body && a.headers && (a.headers["Content-Type"] || (a.headers["Content-Type"] = "application/x-www-form-urlencoded")), this.isSurge() || this.isLoon()) { this.isSurge() && this.isNeedRewrite && (a.headers = a.headers || {}, Object.assign(a.headers, { "X-Surge-Skip-Scripting": !1 })); let c = { method: b, url: a.url, headers: a.headers, timeout: a.timeout, data: a.body }; "get" == b && delete c.data, $axios(c).then(a => { let { status: b, request: c, headers: d, data: e } = a; f(null, c, { statusCode: b, headers: d, body: e }) }).catch(a => console.log(a)) } else if (this.isQuanX()) a.method = b.toUpperCase(), this.isNeedRewrite && (a.opts = a.opts || {}, Object.assign(a.opts, { hints: !1 })), $task.fetch(a).then(a => { let { statusCode: b, request: c, headers: d, body: e } = a; f(null, c, { statusCode: b, headers: d, body: e }) }, a => f(a)); else if (this.isNode()) { this.got = this.got ? this.got : require("got"); let { url: d, ...e } = a; this.instance = this.got.extend({ followRedirect: !1 }), this.instance[b](d, e).then(a => { let { statusCode: b, request: c, headers: d, body: e } = a; f(null, c, { statusCode: b, headers: d, body: e }) }, b => { let { message: c, response: a } = b; f(c, a, a && a.body) }) } } time(a) { let b = { "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() }; for (let c in /(y+)/.test(a) && (a = a.replace(RegExp.$1, ((new Date).getFullYear() + "").substr(4 - RegExp.$1.length))), b) new RegExp("(" + c + ")").test(a) && (a = a.replace(RegExp.$1, 1 == RegExp.$1.length ? b[c] : ("00" + b[c]).substr(("" + b[c]).length))); return a } async showmsg() { if (!this.notifyStr) return; let a = this.name + " \u8FD0\u884C\u901A\u77E5\n\n" + this.notifyStr; if ($.isNode()) { var b = require("./sendNotify"); console.log("\n============== \u63A8\u9001 =============="), await b.sendNotify(this.name, a) } else this.msg(a) } logAndNotify(a) { console.log(a), this.notifyStr += a, this.notifyStr += "\n" } msg(d = t, a = "", b = "", e) { let f = a => { if (!a) return a; if ("string" == typeof a) return this.isLoon() ? a : this.isQuanX() ? { "open-url": a } : this.isSurge() ? { url: a } : void 0; if ("object" == typeof a) { if (this.isLoon()) { let b = a.openUrl || a.url || a["open-url"], c = a.mediaUrl || a["media-url"]; return { openUrl: b, mediaUrl: c } } if (this.isQuanX()) { let d = a["open-url"] || a.url || a.openUrl, e = a["media-url"] || a.mediaUrl; return { "open-url": d, "media-url": e } } if (this.isSurge()) return { url: a.url || a.openUrl || a["open-url"] } } }; this.isMute || (this.isSurge() || this.isLoon() ? $notification.post(d, a, b, f(e)) : this.isQuanX() && $notify(d, a, b, f(e))); let c = ["", "============== \u7CFB\u7EDF\u901A\u77E5 =============="]; c.push(d), a && c.push(a), b && c.push(b), console.log(c.join("\n")) } getMin(a, b) { return a < b ? a : b } getMax(a, b) { return a < b ? b : a } padStr(e, b, f = "0") { let a = String(e), g = b > a.length ? b - a.length : 0, c = ""; for (let d = 0; d < g; d++)c += f; return c + a } json2str(b, e, f = !1) { let c = []; for (let d of Object.keys(b).sort()) { let a = b[d]; a && f && (a = encodeURIComponent(a)), c.push(d + "=" + a) } return c.join(e) } str2json(e, f = !1) { let d = {}; for (let a of e.split("#")) { if (!a) continue; let b = a.indexOf("="); if (-1 == b) continue; let g = a.substr(0, b), c = a.substr(b + 1); f && (c = decodeURIComponent(c)), d[g] = c } return d } randomString(d, a = "abcdef0123456789") { let b = ""; for (let c = 0; c < d; c++)b += a.charAt(Math.floor(Math.random() * a.length)); return b } randomList(a) { let b = Math.floor(Math.random() * a.length); return a[b] } wait(a) { return new Promise(b => setTimeout(b, a)) } done(a = {}) {
*/
            let b = (new Date).getTime(), c = (b - this.startTime) / 1e3; console.log(`
${this.name} Операция завершена, и всего ${c} Второй! `), (this.isSurge() || this.isQuanX() || this.isLoon()) && $done(a)
        }
    }(a, b)
}

Скриптссылка ссылка: https://pan.baidu.com/s/1aeZJzX2YsSmRel34YqoS-g Код извлечения: 52pj

boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose