我用 80 行核心 JS 代码每个月躺着挣一瓶肥宅快乐水

大厂技术  高级前端  Node进阶

点击上方 程序员成长指北,关注公众号

回复1,加入高级Node交流群

今年520活动和618活动开始的时候,京东的京豆签到福利很大,动不动就是1020个京豆,看的小编是激动不已。b6c56986e55cb91ca2a5837331a683a3.jpeg 就是每天都要签到,有时候忙工作忘记签到,一旦断签了心情很是低落🙁,比京豆损失还要难过。小编突发奇想,可以不可以有办法每天定时自动签到呢?经过小编一番苦心研究,发现居然真的可以!!a945709ea914469d7f8823425d856663.jpeg 小编先分享一点小小的战果给各位,有图有真相:

9d71efc39241a68e3f8fbe2cbd0d4bda.jpeg
2641655972507_.pic.jpg
062e14c06754ab4d8fb893787452ab29.jpeg
today.jpg

95ab9fb798be09751917fca6d53d6811.jpeg 小编把相关脚本,用免费的云函数每天定时自动部署触发签到,现在开始每天躺着领10几个京豆,每个月攒的京豆甚至可以免费喝一瓶🥤🥤🥤肥宅快乐水🥤🥤🥤!!!

接下来小编给大家分享一下自动领京豆的JS代码思路,核心代码只需要80行,就可以在Node端成功领取京豆啦!

重要声明:本文只分享自动脚本的思路和部分核心代码逻辑,旨在帮助大家更好的学习Node端技术云函数的相关知识。为了规避相关风险,文章内并不会直接提供源码,思路实现有困难的小伙伴可以咨询小编帮助~

重要声明:少量刷京豆可以怡情,挣几个硬币。不要利用相关技术从事商业活动呦!

如果这篇文章能给您带来一点点的帮助的话,麻烦移动下鼠标点个❤️赞❤️吧!您的点赞会给笔者带来更新的持续动力!

Step.1 身份验证--获取用户cookie

显然第一步我们先要获取我们的用户信息才能每次用脚本自动签到。作为JS前端开发人员,大家都知道用户信息一般都会存储在cookie中(京东的cookie有效时间为30天)。接下来我们只需要登录移动版m.jd.com[1],通过用户名和密码登录(切记),登录完成之后我们就可以在接口找到request请求携带的cookie,如下图所示:

62fbcf67f78fb70600e2983996c6e875.jpeg
image.png
2d62b3e266e7dbd477986f0ce98cea50.jpeg
image.png

我们只要登录完成之后,取出request头里的必要cookie值即可,第一步已经完成了,是不是很简单呢!⭐️

Step.2 服务端发送自动签到接口

拿到cookie之后,我们只需要找到签到领取京豆的相关接口,把cookie按照正确的格式传过去就好啦!代码也很简单(每一行都有注释哦):

const request = require('request');
//步骤一种的cookie值
const KEY = 'pt_pin=xxxxx;pt_key=xxxxx;';
// post通用函数
const postMethod = (options, callback) => {
    // 补上通用的headers
    options.headers['User-Agent'] = 'JD4iPhone/167169 (iPhone; iOS 13.4.1; Scale/3.00)'
    if (options.body) {
        options.headers['Content-Type'] = 'application/x-www-form-urlencoded'
    }
    request.post(options, (error, response, body) => {
        callback(error, response, body)
    })
}
//先去查询用户基本情况 预签到接口
// key:活动关键字 用去区分多种活动  title: 活动标题   acData: 活动编码    ask:加密活动秘钥(非必须) 
function JDUserSignPre(key, title, acData, ask) {
    return new Promise((resolve, reject) => {
        const JDUrl = {
            url: 'https://api.m.jd.com/?client=wh5&functionId=qryH5BabelFloors',
            headers: {
                Cookie: KEY
            },
            //京东接口要求的业务字段 需要去自行爬接口哦
            opts: {
                'filter': 'try{var od=JSON.parse(body);var params=(od.floatLayerList||[]).filter(o=>o.params&&o.params.match(/enActK/)).map(o=>o.params).pop()||(od.floorList||[]).filter(o=>o.template=="signIn"&&o.signInfos&&o.signInfos.params&&o.signInfos.params.match(/enActK/)).map(o=>o.signInfos&&o.signInfos.params).pop();var tId=(od.floorList||[]).filter(o=>o.boardParams&&o.boardParams.turnTableId).map(o=>o.boardParams.turnTableId).pop();var page=od.paginationFlrs;return JSON.stringify({qxAct:params||null,qxTid:tId||null,qxPage:page||null})}catch(e){return `=> 过滤器发生错误: ${e.message}`}'
            },
            //京东接口要求的业务字段 需要去自行爬接口哦
            body: `body=${encodeURIComponent(`{"activityId":"${acData}"${ask ? `,"paginationParam":"2","paginationFlrs":"${ask}"` : ``}}`)}`
        };
        postMethod(JDUrl, async function (error, response, data) {
            try {
                if (error) {
                    throw new Error(error)
                } else {
                    const resultData = JSON.parse(data || '{}');
                    if (data.match(/enActK/)) { // 含有签到数据
                        console.log(`${title}活动查询成功,含有签到数据, 此处可以集中存储${key}用于统一统计活动情况`);
                        const params = resultData.qxAct || (resultData.floatLayerList || []).filter(o => o.params && o.params.match(/enActK/)).map(o => o.params).pop()
                        resolve({
                            params: params
                        }); // 执行签到处理
                    }
                }
            } catch (eor) {
                reject()
            }
        })
    })
}
//签到接口
function JDUserSign(title, body) {
    const JDUrl = {
        url: 'https://api.m.jd.com/client.action?functionId=userSign',
        headers: {
            Cookie: KEY
        },
        body: `body=${body}&client=wh5`
    };
    postMethod(JDUrl, function (error, response, data) {
        try {
            if (error) {
                throw new Error(error)
            } else {
                // 签到成功!
                if (data.match(/签到成功/)) {
                    console.log(`\n${title}签到成功(1)`)
                    if (data.match(/\"text\":\"\d+京豆\"/)) {
                        const count = data.match(/\"text\":\"(\d+)京豆\"/)[1];
                        console.log('成功领取京豆数量为:' + count);
                    }
                } else {
                    console.log('签到失败')
                }
            }
        } catch (err) {
            console.log(err);
        }
    })
}


// 正式开始执行签到
const key = 'JDComputer';
const title = '京东电脑-数码';
const acData = '31HbNBjr6YLyZfJtR5biFFc9ZYXN';
JDUserSignPre(key, title, acData).then(checkRes => {
    JDUserSign(title, checkRes)
}).catch(err => {
    console.log('预查询活动是否可以签到失败', err);
})

这样我们只需要80行代码就完成了第一个签到领京豆接口。所有的活动acData都可以在活动H5页面接口中找到。

其他活动可以自己去寻找哦~~

Step.3 云函数自动触发接口调用,躺着喝快乐水!

阿里云函数提供了非常完备的底层接口,上层的使用比较简单快捷。参考云函数文档基础上,配置好入口函数main.js和配置好定时触发器,即可实现定时调用setp2步骤中的接口。从而达到躺着签到攒京豆的目的!!

另外,还是要注意一下几点即可完成一个云函数搭建:

1、如果需要查询签到的活动接口很多,接口超时时间需要设置成最大900s。

2、Node环境版本号版本号要选择14+。

3、定时触发器的cron表达式为:CRON_TZ=Asia/Shanghai 0 30 1 * * *

贴上步骤图:

2f3661a9110ae9e25f76d7d13b8625a8.jpegaf71149a0883dae507613ee4b57a78c6.jpeg5afb4fcf374f15630404bff893de61eb.jpeg

Step.4 (附加) 将接口调用情况发送到微信

虽然前面三个步骤,我们已经完成了定时调用接口签到领取京豆,已经可以达到目的。但是随着cookie过期或者其他不可抗力因素,难免会存在接口调用失败的情况,那么我们怎么能知道接口调用成功了呢?答案就是:

通过特定公众号开发的消息接口,云函数服务端对接特定公众号的接口,从而达到发送消息的目的。

小编推荐使用Server酱微信通知,使用方法也比较简单:

1、打开 sc.ftqq.com/3.version[2] 按要求绑定微信推。

2、打开sc.ftqq.com/\?c=code[3]获取含有用户信息的消息秘钥scretKey

3、用get请求(可以在浏览器直接访问)发送sc.ftqq.com/\$\{scretKey\}…[4] 即可完成消息发送!

Step.5 写在最后

完成以上步骤 即可自由的实现京豆签到喽!各位读者可以顺着小编的思路进行代码开发,也可以去寻找网络上现成的源码资源哦~ 最后欢迎各位一起讨论,一起愉快的躺着喝肥宅快乐水!!

如果这篇文章能给您带来一点点的帮助的话,麻烦移动下鼠标点个❤️赞❤️吧!您的点赞会给笔者带来更新的持续动力!

关于本文

来自:掘金干货君

https://juejin.cn/post/7112391847133052936

Node 社群


我组建了一个氛围特别好的 Node.js 社群,里面有很多 Node.js小伙伴,如果你对Node.js学习感兴趣的话(后续有计划也可以),我们可以一起进行Node.js相关的交流、学习、共建。下方加 考拉 好友回复「Node」即可。

如果你觉得这篇内容对你有帮助,我想请你帮我2个小忙:

1. 点个「在看」,让更多人也能看到这篇文章2. 订阅官方博客 www.inode.club 让我们一起成长

点赞和在看就是最大的支持
参考资料

[1]

m.jd.com: https://link.juejin.cn?target=m.jd.com

[2]

http://sc.ftqq.com/3.version: https://link.juejin.cn?target=http%3A%2F%2Fsc.ftqq.com%2F3.version

[3]

http://sc.ftqq.com/?c=code: https://link.juejin.cn?target=http%3A%2F%2Fsc.ftqq.com%2F%3Fc%3Dcode

[4]

https://sc.ftqq.com/$%7BscretKey%7D.send?text=%E4%B8%BB%E4%BA%BA%E6%9C%8D%E5%8A%A1%E5%99%A8%E5%8F%88%E6%8C%82%E6%8E%89%E5%95%A6: https://link.juejin.cn?target=https%3A%2F%2Fsc.ftqq.com%2F%24%257BscretKey%257D.send%3Ftext%3D%25E4%25B8%25BB%25E4%25BA%25BA%25E6%259C%258D%25E5%258A%25A1%25E5%2599%25A8%25E5%258F%2588%25E6%258C%2582%25E6%258E%2589%25E5%2595%25A6

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值