这是一个利用 GitHub Action 定时任务实现哔哩哔哩(Bilibili)每日自动投币,点赞,分享视频,直播签到,银瓜子兑换硬币,漫画每日签到,简单配置即可每日轻松获取 65 经验值,快来和我一起成为 Lv6 吧~~~~
- 每天上午 9 点 10 分自动开始任务。【运行时间可自定义】
- 哔哩哔哩漫画每日自动签到 。
- 每日自动从热门视频中随机观看 1 个视频,分享一个视频。
- 每日从热门视频中选取 5 个进行智能投币 【如果投币不能获得经验,默认不投币】
- 投币支持下次一定啦,可自定义每日投币数量。【如果检测到你已经投过币了,则不会投币】
- 大会员月底使用快到期的 B币券,给自己充电,一点也不会浪费哦,默认开启。【可配置】
- 大会员月初 1 号自动领取每月 5 张 B币券 和福利。
- 每日哔哩哔哩直播自动签到,领取签到奖励。【直播你可以不看,但是奖励咱们一定要领】
- 通过server酱推送执行结果到微信。
- Linux用户支持自定义配置了。 ......
- Fork 本项目
- 获取 Bilibili Cookies
- 浏览器打开并登录 bilibili 网站
- 按 F12 打开 「开发者工具」 找到 应用程序/Application -> 存储 -> Cookies
- 找到
bili_jct
SESSDATA
DEDEUSERID
三项,并复制值,创建对应的 GitHub Secrets。
- 点击项目 Settings -> Secrets -> New Secrets 添加以下 3 个 Secrets。
Name | Value |
---|---|
DEDEUSERID | 从 Cookie 中获取 |
SESSDATA | 从 Cookie 中获取 |
BILI_JCT | 从 Cookie 中获取 |
- 开启 Actions 并触发每日自动执行
Github Actions 默认处于关闭状态,还大家请手动开启 Actions ,执行一次工作流,验证是否可以正常工作。
Fork 仓库后,GitHub 默认不自动执行 Actions 任务,请修改 ./github/trigger.json
文件,将 trigger
的值改为 1
,这样每天就会自动执行定时任务了。
{
- "trigger": 0
+ "trigger": 1
}
如果需要修改每日任务执行的时间,请修改 .github/workflows/auto_task_bilili.yml
,在第 12 行左右位置找到下如下配置。
schedule:
- cron: '30 10 * * *'
# cron表达式,Actions时区是UTC时间,所以下午18点要往前推8个小时。
# 示例: 每天晚上22点30执行 '30 14 * * *'
本工具的 Actions 自动构建配置了缓存,平均运行时间在 20s 左右。
如果收到了 GitHub Action 的错误邮件,请检查 Cookies 是不是失效了,用户主动清除浏览器缓存,会导致 BILI_JCT
和 DEDEUSERID
失效
配置文件位于 src/main/resources/config.json
参数示意
Key | Value | 说明 |
---|---|---|
numberOfCoins | [0,5] | 每日投币数量,默认 5 |
selectLike | [0,1] | 投币时是否点赞,默认 0, 0:否 1:是 |
monthEndAutoCharge | [false,true] | 年度大会员月底是否用 B币券 给自己充电,默认 true |
devicePlatform | [ios,android] | 手机端漫画签到时的平台,建议选择你设备的平台 ,默认 ios |
投币数量代码做了处理,如果本日投币不能获得经验了,则不会投币,每天只投能获得经验的硬币。假设你设置每日投币 3 个,早上 7 点你自己投了 2 个硬币,则十点半时,程序只会投 1 个)
- 在linux shell环境执行以下命令,并按照提示输入SESSDATA,DEDEUSERID,BILI_JCT,SCKEY四个参数。
wget https://raw.githubusercontent.com/gitldy1013/bilibili-helper-pro/main/setup.sh && chmod +x ./setup.sh && sudo ./setup.sh
Linux用户使用jar包时如果需要自定义配置,请点此下载配置文件,将其到和jar包同一目录即可,执行时优先加载外部配置文件
bilibili-helper-pro.jar config.json
- 点击 bilibili-helper-pro/release,下载已发布的版本。解压,在解压后的目录打开
Powershell
需要装有 Java 运行环境。
Windows用户使用jar包时如果需要自定义配置,请点此下载配置文件,将其到和jar包同一目录即可,执行时优先加载外部配置文件
- 执行
java -jar /home/bilibili-helper-pro.jar DEDEUSERID SESSDATA BILI_JCT
- 前往 sc.ftqq.com 点击登入,创建账号(建议使用 GitHub 登录)。
- 点击点发送消息 ,生成一个 Key。将其增加到 Github Secrets 中,变量名为
SERVERPUSHKEY
- 绑定微信账号 ,开启微信推送。
目前处于快速迭代阶段,建议通过以下两种方式从本仓库拉取最新代码。
该方案来自 @happy888888
#PR6
,由于源仓库 config.json
文件的更改会覆盖用户自己的 config.json
配置文件,所以暂时没有合并到 main
分支。
使用自定义功能的朋友慎用该方法,建议使用手动拉取的方式,手动解决代码冲突
在 ./github/workflows
目录下创建 auto_merge.yml
文件,内容如下
name: auto_merge
on:
workflow_dispatch:
schedule:
- cron: 0 2 * * fri
# cron表达式,每周五10点执行一次,UTC时间,使用北京时间请+8可按照需求自定义。
jobs:
merge:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
with:
ref: main
fetch-depth: 0
lfs: true
- name: Set git identity
run : |
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --global user.name "github-actions[bot]"
- name: Load upstream commits
run: |
git update-index --assume-unchanged ./src/main/resources/config.json
git pull https://github.com/gitldy1013/bilibili-helper-pro.git --log --no-commit
- name: Apply commit changes
run: |
if [ -f ./.git/MERGE_MSG ]; then
mkdir ./tmp && cp ./.git/MERGE_MSG ./tmp/message
sed -i "1c [bot] AutoMerging: merge all upstream's changes:" ./tmp/message
sed -i '/^\#.*/d' ./tmp/message
git commit --file="./tmp/message"
else
echo "There is no merge commits."
fi
- name: Push Commits
env:
DOWNSTREAM_BRANCH: main
TZ: Asia/Shanghai
run: git push origin $DOWNSTREAM_BRANCH
- 通过
git remote -v
查看是否有源头仓库的别名和地址。
例如这里 origin
就是你自己的仓库,upstream
是你 fork
的源头仓库。
$ git remote -v
origin https://github.com/JunzhouLiu/cxmooc-tools.git (fetch)
origin https://github.com/JunzhouLiu/cxmooc-tools.git (push)
upstream https://github.com/CodFrm/cxmooc-tools.git (fetch)
upstream https://github.com/CodFrm/cxmooc-tools.git (push)
- fork 仓库后,将你的仓库拉到本地,如果没有源头仓库,则添加源头仓库
git remote add upstream https://github.com/gitldy1013/bilibili-helper-pro.git
- 更新上游仓库 main 分支的代码(pull 操作实际上是
fetch+merge
)
git pull upstream main
- 将从源头仓库更新后的代码推送到你自己的 GitHub 仓库
git push origin main
- 这样你就能快速的从我的仓库拉取最新的代码,并更新到你自己的仓库里了。自定义配置的同学,要注意
config.json
不要被我的文件覆盖了。