分享链滴自动签到 puppeteer 脚本

本贴最后更新于 289 天前,其中的信息可能已经时移世改

之前用 phantomjs,发现有 2 个问题,1 是 phantomjs 太老了且停止维护,导致存在兼容性问题,比如有些网站的 js 无法正常解析导致点击或操作无效,2 有时脚本无法自动退出,我想可能还是兼容性问题,导致报错假死吧。

比如,之前用 phantomjs 实现链滴自动签到时就出现了这两个问题,只能通过 cookie 模拟登录然后再模拟签到,虽然勉强可用,但总归不完美。

于是,最近决定研究下 puppeteer,之前没用 puppeteer 的原因,主要考虑到 puppeteer 需要安装 node 环境等,没有 phantomjs 轻量级。

后来发现 puppeteer 比 phantomjs 功能强大且稳定多了,而且 node 环境感觉目前几乎已经是必备的运行时了。

于是动手重写了链滴社区自动签到的脚本,运行了几天,感觉还不错,还算稳定,现在分享给大家,有需要的朋友可以尝试下。

不知道这个脚本是否违规,如果有不妥之处,请管理员大大们告知下,第一时间删除。

脚本整体流程大概是,先访问签到页面,如果发现未登录则先模拟登录,登录完后再进入签到页进行签到,登录后会记录登录信息,下次再次访问签到页面时会带上登录的 cookie,不需要再次登录了。


2024-12-18 更新

增加了二次验证的支持 ,使用前需要执行 npm install otplib 安装 otplib 库,然后参数 twoFactorAuthKey 填写链滴的二次验证秘钥即可,二次验证秘钥可在链滴官网用户设置-> 安全设置-> 两步验证中获取,如果已绑定的需先解绑才能看到。

感谢 @EmptyLight 提供的方法!


代码:

https://gitee.com/wish163/mysoft/blob/main/%E6%80%9D%E6%BA%90/%E9%93%BE%E6%BB%B4%E8%87%AA%E5%8A%A8%E7%AD%BE%E5%88%B0puppeteer%E8%84%9A%E6%9C%AC.js

使用方法:

  1. 先安装 node 环境,已具备的朋友请跳过,有不懂的朋友请自行搜索,教程很多。
  2. 安装 puppeteer,只要执行 npm i puppeteer 或 npm i puppeteer-core 即可。这里推荐 npm i puppeteer-core 方式,因为这种方式不需要安装 200M+ 的 Chrome For Testing,使用 chrome 浏览器的无头模式即可。但本脚本理论上两种方式都支持,但仅在 puppeteer-core 模式下测试通过。
  3. 把以上脚本保存为 js 文件即可,比如,ld246_signin.js,然后运行 node ld246_signin.js 即可。puppeteer 脚本本质上就是 nodejs 脚本,puppeteer 只不过是 nodejs 的一个模块而已,所以,nodejs 环境下的其他库也可以在 puppeteer 中使用。
  4. node ld246_signin.js 放到定时任务中即可,或者开机运行等。比如,我在 Mac 上是这样运行的 0 */1 * * * cd /Users/xxxx/bin/ld246_sign_in/ && /usr/local/bin/node puppeteer_ld246_singin_wilsons.js > /dev/null 2>&1 &,把它放到 crontab 中,每个整点运行一次,这样就保证总会有一次执行自动签到,如果你想提高命中率就把运行间隔设短一点,比如 10 分钟。不用担心重复运行,已签到的情况下,脚本会自动退出不会重复签到。
  5. 签到结果会放到运行脚本目录下的 log.txt 文件里,可以在这里查看每日签到结果及错误信息等。

注意事项:

  1. 用户名和密码必填,这主要用于未登录情况下的自动登录。
  2. chromePath 这个参数是 chrome 浏览器的安装路径,如果你是 Mac 系统通常不需要变动,如果是 Windows 系统需要根据注释说明进行修改,注意,Windows 的路径需要用 \ 进行转义。如果你使用的是 puppeteer 模式而非 puppeteer-core 模式,这个路径设置为空即可,换句话说,如果这个路径为空,则自动使用 puppeteer 模式。
  3. 通知路径脚本,是当签到产生异常时通知你的方式,这里使用 shell 脚本进行编写,你可以自己实现通知方式,如果没有保持为空即可。
  4. userAgent 这个参数可以根据需要更改你自己的浏览器头信息,如果你不清楚勿动即可。
  5. 脚本中的用户名和密码都是明文显示,如果你比较在意可以放到环境变量里,然后通过 process.env.xxxx 读取即可,具体请自行实现。
  6. 登录的 cookie 默认存储到脚本运行目录的 tmp 目录里,且明文保存,如果你担心安全问题,请自行实现加密和解密工作。

Mac 下的简单通知脚本如下:

notify 脚本

#/bin/bash title="提示" if [ "$2" != "" ] ;then title=$2 fi /usr/bin/osascript -e "display notification \" $1 \" with title \"$title\" sound name \"Frog\"" /usr/bin/osascript -e "say \"您有新的通知 $title $1\"";

alert 脚本

#/bin/bash button="知道了" if [ "$2" != "" ] ;then button=$2 fi /usr/bin/osascript -e "say \"您有确认信息 $1 请确认\"" & /usr/bin/osascript -e "tell application \"System Events\" to display alert \"$1\" buttons {\"$button\"} default button 1"

其中,/usr/bin/osascript -e "say \"xxxx xxxx\"" 是语音通知,如果你不需要语音通知,注释或删除即可。

alert 和 notify 的区别是,alert 在发生严重错误,导致流程中断时会弹出,比如登录失败,这个弹窗不会消失,除非用户手动点击;而通知则是简单提醒,通常过一会会自动消失。

但,如果是你自己实现的通知脚本,那就看你如何定义了。

最后,放一个签到脚本的整体流程图吧。

puppeteer 链滴自动签到流程图.png

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    25893 引用 • 107282 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1281 回帖 • 2 关注
  • Puppeteer
    7 引用 • 33 回帖
  • 签到
    39 引用 • 395 回帖 • 10 关注
4 操作
wilsons 在 2024-12-18 18:18:36 更新了该帖
wilsons 在 2024-12-18 18:12:53 更新了该帖
wilsons 在 2024-12-18 18:10:48 更新了该帖
wilsons 在 2024-12-18 18:09:02 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • HugZephyr

    该说不说, 我非常需要这个, 但是合不合法就不知道了 😂

    1 回复
  • wilsons 1

    哈哈哈,所以等管理员没反应过来前保存 😄

  • 巨佬牛逼

    可惜我的小卡拉米服务器估计带着比较吃力

    1 回复
  • wilsons 1

    没问题的,还算轻量级,仅安装 puppeteer 模块,才 6M 多大小,运行 Chrome 无头模式,通常 120M 左右内存,CPU 5% 以内,通常只需要运行几秒就退出了,服务器根本还没反应过来就退出了。😂

    1 回复
  • 感谢大佬,现在就试试trollface

  • wilsons 1

    其实还有一种简单的方法

    1. 浏览器安装油猴扩展 https://www.tampermonkey.net/

    2. 安装链滴每日签到油猴脚本 https://greasyfork.org/zh-CN/scripts/492637

    3. 打开链滴每日签到页面 https://ld246.com/activity/checkin 然后将页面保存为应用

      image.png

    4. 使用定时任务,定时打开这个应用即可。

    5. 如果想隐藏打开这个应用,Windows 很多方式,比如 vbs 脚本等,Mac 可以使用自动化任务脚本等。

      比如:

      appName="每日签到 - 活动 - 链滴" appPath="/Users/xxxx/Applications/Chrome Apps.localized" open -a "$appPath/$appName.app" && sleep 1 && osascript -e "tell application \"$appName\" to tell window 1 to set visible to false" && sleep 10 && osascript -e "tell application \"$appName\" to quit"
  • pakeh2866

    感谢分享,学习了~

  • EmptyLight

    脚本没处理 totp 二次验证的情况,我说怎么登不进去。。。现在动手重写有关二次验证的部分

    1 回复
  • wilsons 1 2 评论

    是的,你可以改进下。

    二次验证,需要自己实现一个动态秘钥生成客户端。

    具体代码放不出来,触发安全验证了,就连输入框、按钮的选择器都不能放
    EmptyLight
    用一个 otpauth 库就能生成 totp,再配合原有的代码写一下就能填写 totp
    EmptyLight
  • wilsons 1 3 评论

    @EmptyLight

    代码放不出来什么意思?

    嗯,你自己实现吧,暂时不支持二次验证。

    链滴有评论区的检测机制,如果有敏感信息会提醒你发不出来,比如 totp 之类的
    EmptyLight
    @EmptyLight 可以放到 gitee 等链接过来即可,放到文本文件然后网盘链接也行。不过,这个检测应该不是安全问题,可能是链滴页面长久未刷新导致的,一般刷新下页面就可以了。
    wilsons
    文章地址 GitHub PageCOS)
    EmptyLight 1
  • EmptyLight 1 评论

    提醒一下,otp 密钥可以在自己的 otp 管理软件里面查看,不一定需要重新绑定。如果你用 Microsoft Authoricator 的我没法给出步骤,因为我没用过。不过我自己用的是 KeepassXC,不管是 Keepass 插件还是 KeepassXC、KeepassDX 都可以自己看 otp 密钥。

    感谢提醒!可能有些 app 提供了这个功能,我用的 Google Authenticator 不知道能否查看,没找到。不过,重新绑定是万能方法,哈哈哈。
    wilsons
  • 值得支持,按照佬的配置,完全没问题

请输入回帖内容 ...
wilsons
正在努力开发 wilsons 工具箱中 🛠️ 目前已正式入驻爱发电啦!💖 想催更、提需求?欢迎访问 👉 https://afdian.com/a/wilsons

推荐标签 标签

  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    434 引用 • 1238 回帖 • 592 关注
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 177 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 4 关注
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 612 关注
  • danl
    174 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 653 关注
  • 反馈

    Communication channel for makers and users.

    120 引用 • 906 回帖 • 279 关注
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    117 引用 • 99 回帖 • 199 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    52 引用 • 228 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖
  • 脑图

    脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。

    32 引用 • 99 回帖
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 370 关注
  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1395 回帖
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 51 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 3 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    284 引用 • 248 回帖
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 615 关注
  • 招聘

    哪里都缺人,哪里都不缺人。

    188 引用 • 1057 回帖 • 1 关注
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖 • 2 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 451 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    326 引用 • 1395 回帖
  • 印象笔记
    3 引用 • 16 回帖 • 1 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 34 关注
  • 国际化

    i18n(其来源是英文单词 internationalization 的首末字符 i 和 n,18 为中间的字符数)是“国际化”的简称。对程序来说,国际化是指在不修改代码的情况下,能根据不同语言及地区显示相应的界面。

    8 引用 • 26 回帖
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    16 引用 • 236 回帖 • 253 关注
  • OpenCV
    15 引用 • 36 回帖 • 7 关注