BilibiliTask
Bilibili 助手
👯✨😄📫
正式去除 Actions 执行方式,后续会适配云函数
哔哩哔哩(B
站)自动完成每日任务,
投币,点赞,直播签到,自动兑换银瓜子为硬币,自动送出即将过期礼物,漫画App
签到,大会员领取B
币卷等。每天获得65
点经验,助你快速升级到Lv6
。
开源不易,如果本项目对你有帮助,那么就请给个star
吧。😄
重要提示,如果收到了b
站的账号安全通知,可以考虑将Actions
禁用一段时间,观望一段时间再进行使用,具体禁用步骤,请参考此Issues。
功能
- [x] 自动获取经验(投币、点赞、分享视频)
- [x] 直播辅助(直播签到,自动送出即将过期的礼物)
- [x] 自动兑换银瓜子为硬币
- [x] 自动领取年度大会员每月权益(每月
1
号领取B
币劵、权益礼包) - [x] 月底自动用 B 币卷给自己充电(每月
28
号) - [x] 月底自动用 B 币卷兑换金瓜子(每月
28
号) - [x] 漫画辅助脚本(漫画
APP
签到) - [x] 支持功能自定义(自定义投币数量,银瓜子兑换硬币开关等)
- [x] 账户失效提醒(发送到你的微信或者钉钉提醒、邮箱提醒)
- [x] 支持多种方式推送运行结果(钉钉、微信)
- [x] 支持 Docker 自己部署
目录
关于日志中的 ✔ 和 ❌ 说明
符号 | 说明 |
---|---|
✔ | 本次程序运行,成功的执行了代码,并完成了任务(例如,分享视频,今日未分享过,那么程序就应该请求分享视频的接口,协助完成分享视频的任务)。 |
❌ | 可能两种操作会出现这个符号。1.程序成功的执行了,尝试去完成任务,但是中途遇到了未知的失败。2.程序成功的执行了,检测到此类任务已经完成(例如,分享视频,今日已经分享过,那么程序不应该请求分享视频的接口,无需协助完成分享视频的任务),就无需再去完成。可以理解为跳过或遇到错误。 |
进阶使用
1.配置文件说明
配置文件的位置在src/main/resource/config.yml
。
重要提示!!!
程序检测到礼物有效期还剩1
天,将会自动随机送出,部分朋友包裹里可能会有贵重礼物,你可以手动关闭即将过期礼物送出功能。
需要在config.yml
中,将gift
项设置为false
。详情见下方配置文件说明。
符号 | 说明 |
---|---|
coin | 代表投币的数量 [0,5] |
gift | 是否需要送出即将过期礼物 [true,false] |
s2c | 是否需要将银瓜子兑换硬币 [true,false] |
autoBiCoin | 月底自动使用 B 币卷 [{0,自己有其他用途},{1,给自己充电},{2,兑换成金瓜子}] |
platform | 用户设备的标识[android,ios] |
upList | up 主列表,优先给这些 up 主投币[uid] |
manga | 是否自动进行漫画签到 [true,false] |
upLive | 即将过期礼物给此 up 的直播间,填写其 uid |
selectLike | 对于进行投币的视频选择是否点赞 , 默认不点赞 [0,1] |
#每天需要投币的数量 [0,5]。
coin: 5
#送出即将过期礼物 [true,false]
gift: true
#银瓜子兑换为硬币 [true,false]
s2c: true
#月底自动使用 B 币卷 [{0,自己会使用},{1,给自己充电},{2,兑换成金瓜子}]
autoBiCoin: 1
#用户设备的标识 [android,ios]
platform: android
#自定义优先给这些 up 的视频投币 , 以 yml 数组的形式 , 填写其 uid (mid)
upList:
- 477137547
- 14602398
#进行漫画签到任务 [true,false]
manga: true
#优先送出即将过期礼物给此 up 的直播间,填写其 uid
upLive: 477137547
#对于进行投币的视频选择是否点赞 , 默认不点赞 [0,1]
selectLike: 0
如实在没有想给他投币的 up 主,可以考虑把我填上哦 477137547
😄
Docker 部署方法
- 使用如下命令请自行替换所需的环境变量
- 每天 00:01 分运行程序
(shell script) docker run -d \ --env BILI_JCT=自行填写 \ --env DEDEUSERID=自行填写 \ --env SESSDATA=自行填写 \ timmyovo/bilibilitask
2.推送运行结果到微信
使用server
酱将程序运行结果推送到微信
server
酱官网:http://sc.ftqq.com
按照
server
酱官网使用教程,用github
登录并绑定微信。获得
SCKEY
并将其填入到Secrets
中。
在Secrets
中的Name
和Value
格式如下:
Name | Value |
---|---|
SCKEY | xxxxx |
这样就可以在微信接收到运行结果了。
使用server
酱测试号版推送运行结果到微信
server
酱测试号版官网:https://sct.ftqq.com/
按照
server
酱测试号版官网使用教程,用微信扫码登录。获得
SENDKEY
并将其填入到Secrets
中。
Name | Value |
---|---|
SENDKEY | xxxxx |
使用push+
推送运行结果到微信
注意:pushplus 进行了升级,查看pushplus 后续暂停维护通知
push+
官网:http://www.pushplus.plus
进入官网首页点击
一对一推送
,用微信扫描其二维码,进行关注关注后,即可看到
token
,将其添加到Secrets
中即可
在Secrets
中的Name
和Value
格式如下:
Name | Value |
---|---|
PUSHPLUSTK | xxxxx |
3.推送运行结果到钉钉
1.首先,你需要在钉钉创建一个群聊,可以拉去两个人创建一个,再把他们踢出去。
2.获取钉钉自定义机器人的Webhook
,将其填写到Secrets
中
键值对如下格式:
Name | Value |
---|---|
DINGTALK | https://oapi.dingtalk.com/robot/send?access_token=064559acaa666c43d5ba197656594f288f3acef9a64f4f43218beddd1c7b7050 |
4.使用Telegram bot
推送运行结果到Telgram
群组
- 首先需要创建 telegram bot 并获取 telegram bot token,可以参考文档;
- 将机器人加入群组中,并获取群组 ID,查看Stackoverflow 问答;
- 将 telegram bot token 和群组 ID 添加到
Secrets
中即可。
在Secrets
中的Name
和Value
格式如下:
Name | Value |
---|---|
TELEGRAM_BOT_TOKEN | xxxxx |
TELEGRAM_CHAT_ID | xxxxx |
5.自定义程序运行时间
在.github/workflows/Bilibili.yml
修改cron
表达式,需要注意的是,cron
表达式是国际时间,
需要换算到国内时间,往后推 8 个小时,例如国际时间是 12 点钟,则在国内是 20 点钟。
如何拉取最新代码
方法一
在github
安装pull
,会自动帮你检测上游仓库,并帮助你更新代码
地址在这: https://github.com/apps/pull
由于添加有配置文件config.yml
,有可能会覆盖你自定义的config.yml
,需要注意。
方法二
1、查看是否有源头仓库的别名和地址
$ git remote -v
origin https://github.com/cmdcs/BilibiliTask.git (fetch)
origin https://github.com/cmdcs/BilibiliTask.git (push)
upstream https://github.com/srcrs/BilibiliTask (fetch)
upstream https://github.com/srcrs/BilibiliTask (push)
origin
是你的仓库地址,upstream
是你fork
的源头仓库。通常第一次是没有upstream
的。
2、添加源头仓库
git remote add upstream https://github.com/srcrs/BilibiliTask
3、把上游仓库main
分支的更新拉取到本地
git pull upstream main
4、将更新后的代码推送到你的仓库
git push origin main
由于添加有配置文件config.yml
,有可能会覆盖你自定义的config.yml
,需要注意。