diff --git a/githubAction.md b/githubAction.md index 1adece00..251409bc 100644 --- a/githubAction.md +++ b/githubAction.md @@ -80,7 +80,7 @@ | `JOIN_PK_TEAM` | 东东超市
自动参加PK队伍 | 非必须 | 每次pk活动参加作者创建的pk队伍,`true`表示参加,`false`表示不参加 | | `SUPERMARKET_LOTTERY` | 东东超市抽奖 | 非必须 | 每天运行脚本是否使用金币去抽奖,`true`表示抽奖,`false`表示不抽奖 | | `FRUIT_BEAN_CARD` | 东东农场
使用水滴换豆卡 | 非必须 | 东东农场使用水滴换豆卡(如果出现限时活动时100g水换20豆,此时比浇水划算,推荐换豆),
`true`表示换豆(不浇水),`false`表示不换豆(继续浇水),脚本默认是浇水 | -| `UN_SUBSCRIBES` | jd_unsubscribe.js | 非必须 | 共四个参数,换行隔开.四个参数分别表示
`取关商品数量`,`取关店铺数量`,`遇到此商品不再进行取关`,`遇到此店铺不再进行取关`,[具体使用往下看](#取关店铺secret的说明) | +| `UN_SUBSCRIBES` | jd_unsubscribe.js | 非必须 | 共四个参数,换行隔开.四个参数分别表示
`是否取关全部商品(0表示一个都不)`,`是否取关全部店铺数(0表示一个都不)`,`遇到此商品不再进行取关`,`遇到此店铺不再进行取关`,[具体使用往下看](#取关店铺环境变量的说明) | | `JDJOY_HELPSELF` | 疯狂的JOY
循环助力 | 非必须 | 疯狂的JOY循环助力,`true`表示循环助力,`false`表示不循环助力,默认不开启循环助力。 | | `JDJOY_APPLYJDBEAN` | 疯狂的JOY
京豆兑换 | 非必须 | 疯狂的JOY京豆兑换,目前最小值为2000京豆(详情请查看活动页面-提现京豆),
默认数字`0`不开启京豆兑换。 | | `BUY_JOY_LEVEL` | 疯狂的JOY
购买joy等级 | 非必须 | 疯狂的JOY自动购买什么等级的JOY | @@ -110,25 +110,12 @@ -#### 取关店铺secret的说明 +#### 取关店铺环境变量的说明 - > secret依次是`取关商品数`,`取关店铺数`,`遇到此商品不再进行取关`,`遇到此店铺不再进行取关` + > 环境变量内容的意思依次是`是否取关全部商品(0表示一个都不)`,`是否取关全部店铺数(0表示一个都不)`,`遇到此商品不再进行取关`,`遇到此店铺不再进行取关` -例如我要取关 `100`个商品,`100`个店铺,商品遇到商品关键字 `iPhone12` 停止取关,店铺遇到 `Apple京东自营旗舰店` 不再取关 -则使用`换行`或者`&`隔开即可, -下面给出换行隔开示例: - - ``` -100 -100 -iPhone12 -Apple京东自营旗舰店 - ``` - -下面给出`&`符号隔开示例: - ``` -100&100&iPhone12&Apple京东自营旗舰店 - ``` +例如1:不要取关任何商品和店铺,则输入`0&0` +例如2:我想商品遇到关键字 `iPhone12` 停止取关,店铺遇到 `Apple京东自营旗舰店` 不再取关,则输入`10&10&iPhone12&Apple京东自营旗舰店`(前面两个参数非0即可) #### 关于脚本推送通知频率 diff --git a/jd_beauty.js b/jd_beauty.js index 8c7588e2..662eb845 100644 --- a/jd_beauty.js +++ b/jd_beauty.js @@ -207,7 +207,7 @@ async function mr() { if (e.data !== 'pong' && e.data && safeGet(e.data)) { let vo = JSON.parse(e.data); await $.wait(Math.random()*2000+500); - console.log(`开始任务:"${JSON.stringify(vo.action)}`); + console.log(`\n开始任务:"${JSON.stringify(vo.action)}`); switch (vo.action) { case "get_ad": console.log(`当期活动:${vo.data.screen.name}`) @@ -360,8 +360,7 @@ async function mr() { break case "material_fetch_v2": if (vo.code === '200' || vo.code === 200) { - console.log(vo) - console.log(`【${vo.data.position}】收取成功,获得${vo.data.procedure.produce_num}份${vo.data.material_name}`) + console.log(`【${vo.data.position}】收取成功,获得${vo.data.procedure.produce_num}份${vo.data.material_name}\n`); } else { console.log(`任务完成失败,错误信息${vo.msg}`) } diff --git a/jd_unsubscribe.js b/jd_unsubscribe.js index 0c370a91..07de6bca 100644 --- a/jd_unsubscribe.js +++ b/jd_unsubscribe.js @@ -1,10 +1,10 @@ /* 脚本:取关京东店铺和商品 -更新时间:2021-04-12 +更新时间:2021-05-08 因种豆得豆和宠汪汪以及NobyDa大佬的京东签到脚本会关注店铺和商品,故此脚本用来取消已关注的店铺和商品 -默认每运行一次脚本取消关注10个商品,10个店铺。可结合boxjs自定义取消多少个(目前测试通过最大数量是一次性取消300个商品无异常,大于300请自行测试,建议尽量不要一次性全部取消以免出现问题)。 +默认:每运行一次脚本全部已关注的店铺与商品 建议此脚本运行时间在 种豆得豆和宠汪汪脚本运行之后 再执行 -现有功能: 1、取关商品。2、取关店铺。3、匹配到boxjs输入的过滤关键词后,不再进行此商品/店铺后面(包含输入的关键词商品/店铺)的取关。4、支持京东双账号 +现有功能: 1、取关商品。2、取关店铺。3、匹配到boxjs输入的过滤关键词后,不再进行此商品/店铺后面(包含输入的关键词商品/店铺)的取关 脚本兼容: Quantumult X, Surge, Loon, JSBox, Node.js, 小火箭 ==============Quantumult X=========== [task_local] @@ -29,13 +29,14 @@ if ($.isNode()) { Object.keys(jdCookieNode).forEach((item) => { cookiesArr.push(jdCookieNode[item]) }) - if (process.env.JD_DEBUG && process.env.JD_DEBUG === 'false') console.log = () => {}; + if (process.env.JD_DEBUG && process.env.JD_DEBUG === 'false') console.log = () => { + }; } else { cookiesArr = [$.getdata('CookieJD'), $.getdata('CookieJD2'), ...jsonParse($.getdata('CookiesJD') || "[]").map(item => item.cookie)].filter(item => !!item); } const jdNotify = $.getdata('jdUnsubscribeNotify');//是否关闭通知,false打开通知推送,true关闭通知推送 -let goodPageSize = $.getdata('jdUnsubscribePageSize') || 20;// 运行一次取消多少个已关注的商品。数字0表示不取关任何商品 -let shopPageSize = $.getdata('jdUnsubscribeShopPageSize') || 20;// 运行一次取消多少个已关注的店铺。数字0表示不取关任何店铺 +let goodPageSize = $.getdata('jdUnsubscribePageSize') || 20;// 运行一次取消多全部已关注的商品。数字0表示不取关任何商品 +let shopPageSize = $.getdata('jdUnsubscribeShopPageSize') || 20;// 运行一次取消全部已关注的店铺。数字0表示不取关任何店铺 let stopGoods = $.getdata('jdUnsubscribeStopGoods') || '';//遇到此商品不再进行取关,此处内容需去商品详情页(自营处)长按拷贝商品信息 let stopShop = $.getdata('jdUnsubscribeStopShop') || '';//遇到此店铺不再进行取关,此处内容请尽量从头开始输入店铺名称 const JD_API_HOST = 'https://wq.jd.com/fav'; @@ -51,7 +52,7 @@ const JD_API_HOST = 'https://wq.jd.com/fav'; $.isLogin = true; $.nickName = ''; await TotalBean(); - console.log(`\n开始【京东账号${$.index}】${$.nickName || $.UserName}\n`); + console.log(`\n****开始【京东账号${$.index}】${$.nickName || $.UserName}*****\n`); if (!$.isLogin) { $.msg($.name, `【提示】cookie已失效`, `京东账号${$.index} ${$.nickName || $.UserName}\n请重新登录获取\nhttps://bean.m.jd.com/bean/signIndex.action`, {"open-url": "https://bean.m.jd.com/bean/signIndex.action"}); @@ -72,16 +73,19 @@ const JD_API_HOST = 'https://wq.jd.com/fav'; .finally(() => { $.done(); }) -async function jdUnsubscribe(doubleKey) { + +async function jdUnsubscribe() { await Promise.all([ - unsubscribeGoods(doubleKey), - unsubscribeShops() + goodsMain(), + shopMain() ]) + //再次获取还有多少已关注的店铺与商品 await Promise.all([ - getFollowShops(), - getFollowGoods() + getFollowGoods(), + getFollowShops() ]) } + function showMsg() { if (!jdNotify || jdNotify === 'false') { $.msg($.name, ``, `【京东账号${$.index}】${$.nickName}\n【已取消关注店铺】${$.unsubscribeShopsCount}个\n【已取消关注商品】${$.unsubscribeGoodsCount}个\n【还剩关注店铺】${$.shopsTotalNum}个\n【还剩关注商品】${$.goodsTotalNum}个\n`); @@ -89,47 +93,53 @@ function showMsg() { $.log(`\n【京东账号${$.index}】${$.nickName}\n【已取消关注店铺】${$.unsubscribeShopsCount}个\n【已取消关注商品】${$.unsubscribeGoodsCount}个\n【还剩关注店铺】${$.shopsTotalNum}个\n【还剩关注商品】${$.goodsTotalNum}个\n`); } } -function unsubscribeGoods() { - return new Promise(async (resolve) => { - let followGoods = await getFollowGoods(); - if (followGoods.iRet === '0') { - let count = 0; - $.unsubscribeGoodsCount = count; - if ((goodPageSize * 1) !== 0) { - if (followGoods.totalNum > 0) { - for (let item of followGoods.data) { - console.log(`是否匹配::${item.commTitle.indexOf(stopGoods.replace(/\ufffc|\s*/g, ''))}`) +async function goodsMain() { + $.unsubscribeGoodsCount = 0; + if ((goodPageSize * 1) !== 0) { + await unsubscribeGoods(); + const le = Math.ceil($.goodsTotalNum / 20) - 1 >= 0 ? Math.ceil($.goodsTotalNum / 20) - 1 : 0; + for (let i = 0; i < new Array(le).length; i++) { + await $.wait(100); + await unsubscribeGoods(); + } + } else { + console.log(`\n您设置的是不取关商品\n`); + } +} - if (stopGoods && item.commTitle.indexOf(stopGoods.replace(/\ufffc|\s*/g, '')) > -1) { - console.log(`匹配到了您设定的商品--${stopGoods},不在进行取消关注商品`) - break; - } - let res = await unsubscribeGoodsFun(item.commId); - // console.log('取消关注商品结果', res); - if (res.iRet === 0 && res.errMsg === 'success') { - console.log(`取消关注商品---${item.commTitle.substring(0, 20).concat('...')}---成功\n`) - count ++; - } else { - console.log(`取消关注商品---${item.commTitle.substring(0, 20).concat('...')}---失败\n`) - } - } - $.unsubscribeGoodsCount = count; - resolve(count) - } else { - resolve(count) +async function unsubscribeGoods() { + let followGoods = await getFollowGoods(); + if (followGoods.iRet === '0') { + if (followGoods.totalNum > 0) { + for (let item of followGoods['data']) { + console.log(`是否匹配::${item.commTitle.indexOf(stopGoods.replace(/\ufffc|\s*/g, ''))}`) + if (stopGoods && item.commTitle.indexOf(stopGoods.replace(/\ufffc|\s*/g, '')) > -1) { + console.log(`匹配到了您设定的商品--${stopGoods},不在进行取消关注商品`) + break; } - } else { - console.log(`\n您设置的是不取关商品\n`); - resolve(count); + let res = await unsubscribeGoodsFun(item.commId); + if (res.iRet === 0 && res.errMsg === 'success') { + console.log(`取消关注商品---${item.commTitle.substring(0, 20).concat('...')}---成功`) + $.unsubscribeGoodsCount++; + console.log(`已成功取消关注【商品】:${$.unsubscribeGoodsCount}个\n`) + } else { + console.log(`取关商品失败:${JSON.stringify(res)}`) + console.log(`取消关注商品---${item.commTitle.substring(0, 20).concat('...')}---失败\n`) + } + await $.wait(1000); } } - }) + } else { + console.log(`获取已关注商品失败:${JSON.stringify(followGoods)}`); + } } + function getFollowGoods() { + $.goodsTotalNum = 0; return new Promise((resolve) => { const option = { - url: `${JD_API_HOST}/comm/FavCommQueryFilter?cp=1&pageSize=${goodPageSize}&_=${Date.now()}&category=0&promote=0&cutPrice=0&coupon=0&stock=0&areaNo=1_72_4139_0&sceneval=2&g_login_type=1&callback=jsonpCBKB&g_ty=ls`, + url: `${JD_API_HOST}/comm/FavCommQueryFilter?cp=1&pageSize=20&_=${Date.now()}&category=0&promote=0&cutPrice=0&coupon=0&stock=0&areaNo=1_72_4139_0&sceneval=2&g_login_type=1&callback=jsonpCBKB&g_ty=ls`, headers: { "Host": "wq.jd.com", "Accept": "*/*", @@ -141,11 +151,15 @@ function getFollowGoods() { "Accept-Encoding": "gzip, deflate, br" }, } - $.get(option, (err, resp, data) => { + $.get(option, async (err, resp, data) => { try { data = JSON.parse(data.slice(14, -13)); - $.goodsTotalNum = data.totalNum; - // console.log('data', data.data.length) + if (data.iRet === '0') { + $.goodsTotalNum = data.totalNum; + console.log(`当前已关注【商品】:${$.goodsTotalNum}个\n`) + } else { + $.goodsTotalNum = 0; + } } catch (e) { $.logErr(e, resp); } finally { @@ -154,6 +168,7 @@ function getFollowGoods() { }); }) } + function unsubscribeGoodsFun(commId) { return new Promise(resolve => { const option = { @@ -183,44 +198,50 @@ function unsubscribeGoodsFun(commId) { }) } -function unsubscribeShops() { - return new Promise(async (resolve) => { - let followShops = await getFollowShops(); - if (followShops.iRet === '0') { - let count = 0; - $.unsubscribeShopsCount = count; - if ((shopPageSize * 1) !== 0) { - if (followShops.totalNum > 0) { - for (let item of followShops.data) { - if (stopShop && (item.shopName && item.shopName.indexOf(stopShop.replace(/\s*/g, '')) > -1)) { - console.log(`匹配到了您设定的店铺--${item.shopName},不在进行取消关注店铺`) - break; - } - let res = await unsubscribeShopsFun(item.shopId); - // console.log('取消关注店铺结果', res); - if (res.iRet === '0') { - console.log(`取消已关注店铺---${item.shopName}----成功\n`) - count ++; - } else { - console.log(`取消已关注店铺---${item.shopName}----失败\n`) - } - } - $.unsubscribeShopsCount = count; - resolve(count) - } else { - resolve(count) +async function shopMain() { + $.unsubscribeShopsCount = 0; + if ((shopPageSize * 1) !== 0) { + await unsubscribeShops(); + const le = Math.ceil($.shopsTotalNum / 20) - 1 >= 0 ? Math.ceil($.shopsTotalNum / 20) - 1 : 0; + for (let i = 0; i < new Array(le).length; i++) { + await $.wait(100); + await unsubscribeShops(); + } + } else { + console.log(`\n您设置的是不取关店铺\n`); + } +} + +async function unsubscribeShops() { + let followShops = await getFollowShops(); + if (followShops.iRet === '0') { + if (followShops.totalNum > 0) { + for (let item of followShops.data) { + if (stopShop && (item.shopName && item.shopName.indexOf(stopShop.replace(/\s*/g, '')) > -1)) { + console.log(`匹配到了您设定的店铺--${item.shopName},不在进行取消关注店铺`) + break; } - } else { - console.log(`\n您设置的是不取关店铺\n`); - resolve(count) + let res = await unsubscribeShopsFun(item.shopId); + if (res.iRet === '0') { + console.log(`取消已关注店铺---${item.shopName}----成功`) + $.unsubscribeShopsCount++; + console.log(`已成功取消关注【店铺】:${$.unsubscribeShopsCount}个\n`) + } else { + console.log(`取消已关注店铺---${item.shopName}----失败\n`) + } + await $.wait(1000); } } - }) + } else { + console.log(`获取已关注店铺失败:${JSON.stringify(followShops)}`); + } } + function getFollowShops() { + $.shopsTotalNum = 0; return new Promise((resolve) => { const option = { - url: `${JD_API_HOST}/shop/QueryShopFavList?cp=1&pageSize=${shopPageSize}&_=${Date.now()}&sceneval=2&g_login_type=1&callback=jsonpCBKA&g_ty=ls`, + url: `${JD_API_HOST}/shop/QueryShopFavList?cp=1&pageSize=20&_=${Date.now()}&sceneval=2&g_login_type=1&callback=jsonpCBKA&g_ty=ls`, headers: { "Host": "wq.jd.com", "Accept": "*/*", @@ -235,7 +256,12 @@ function getFollowShops() { $.get(option, (err, resp, data) => { try { data = JSON.parse(data.slice(14, -13)); - $.shopsTotalNum = data.totalNum; + if (data.iRet === '0') { + $.shopsTotalNum = data.totalNum; + console.log(`当前已关注【店铺】:${$.shopsTotalNum}个\n`) + } else { + $.shopsTotalNum = 0; + } } catch (e) { $.logErr(e, resp); } finally { @@ -244,6 +270,7 @@ function getFollowShops() { }); }) } + function unsubscribeShopsFun(shopId) { return new Promise(resolve => { const option = { @@ -270,6 +297,7 @@ function unsubscribeShopsFun(shopId) { }); }) } + function TotalBean() { return new Promise(async resolve => { const options = { @@ -314,6 +342,7 @@ function TotalBean() { }) }) } + function requireConfig() { return new Promise(resolve => { if ($.isNode() && process.env.UN_SUBSCRIBES) { @@ -326,7 +355,7 @@ function requireConfig() { } else { $.UN_SUBSCRIBES = process.env.UN_SUBSCRIBES.split(); } - console.log(`您secret设置的取关参数:\n${JSON.stringify($.UN_SUBSCRIBES)}`) + console.log(`您环境变量 UN_SUBSCRIBES 设置的内容为:\n${JSON.stringify($.UN_SUBSCRIBES)}`) goodPageSize = $.UN_SUBSCRIBES[0] || goodPageSize; shopPageSize = $.UN_SUBSCRIBES[1] || shopPageSize; stopGoods = $.UN_SUBSCRIBES[2] || stopGoods; @@ -335,6 +364,7 @@ function requireConfig() { resolve() }) } + function jsonParse(str) { if (typeof str == "string") { try {