分享链滴自动签到 puppeteer 脚本

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

之前用 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

  • 思源笔记

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

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

    25229 引用 • 104040 回帖
  • JavaScript

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

    730 引用 • 1280 回帖 • 4 关注
  • Puppeteer
    7 引用 • 32 回帖
  • 签到
    39 引用 • 394 回帖 • 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 更新了该帖

相关帖子

欢迎来到这里!

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

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

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

    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
人生最大的敌人是自己,战胜自己,才能超越一切。

推荐标签 标签

  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 104 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 691 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 724 关注
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖 • 1 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖 • 2 关注
  • OAuth

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

    36 引用 • 103 回帖 • 31 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 2 关注
  • Outlook
    1 引用 • 5 回帖
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    498 引用 • 1395 回帖 • 249 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 630 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 54 回帖 • 8 关注
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 110 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 5 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    187 引用 • 318 回帖 • 256 关注
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    76 引用 • 258 回帖 • 626 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 1 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    20 引用 • 23 回帖 • 740 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 3 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 227 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    22 引用 • 214 回帖
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 5 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    83 引用 • 37 回帖 • 1 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 81 关注
  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    948 引用 • 1460 回帖 • 1 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1441 引用 • 10068 回帖 • 494 关注