Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Womsxd/MihoyoBBSTools
Womsxd/AutoMihoyoBBS,米游社相关脚本
https://github.com/Womsxd/MihoyoBBSTools
genshin genshin-impact
Last synced: about 2 months ago
JSON representation
Womsxd/AutoMihoyoBBS,米游社相关脚本
- Host: GitHub
- URL: https://github.com/Womsxd/MihoyoBBSTools
- Owner: Womsxd
- License: mit
- Created: 2023-02-07T00:45:10.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-05-13T00:55:44.000Z (8 months ago)
- Last Synced: 2024-05-13T01:43:00.791Z (8 months ago)
- Topics: genshin, genshin-impact
- Language: Python
- Homepage:
- Size: 1000 KB
- Stars: 611
- Watchers: 11
- Forks: 121
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# 米游社辅助签到
基于 Python3 的米游社辅助签到项目
禁止大范围宣传本项目,谢谢配合
请不要发B站,谢谢
也请不要滥用本项目
⚠️ **对于Fork的开发者/用户,请不要滥用GitHub Action,因为 GitHub 将计算您的分支 GitHub Actions 使用量并归属到上游存储库,这可能导致 GitHub 停用此上游存储库**
- 此项目的用途
这是一个米游社的辅助签到项目,包含了以下功能
1.自动获取米游币
2.支持国服:崩坏学院2、崩坏3、未定事件簿、原神、崩坏:星穹铁道、绝区零 的游戏签到
3.支持国际服:崩坏3、未定事件簿、原神、崩坏:星穹铁道、绝区零的游戏签到
## 如何使用程序
- **部署方法**
1. 使用[Git](https://git-scm.com/)或[点击此处](https://github.com/Womsxd/MihoyoBBSTools/archive/refs/heads/master.zip)下载本项目
2. 下载[Python3](https://www.python.org/downloads/)
3. 解压本项目压缩包,在解压目录中**Shift+右键** 打开你的命令提示符 cmd 或 powershell
4. [requirements.txt](https://raw.githubusercontent.com/Womsxd/MihoyoBBSTools/master/requirements.txt) 是所需第三方模块,执行 `pip install -r requirements.txt` 安装模块
5. 打开目录中的**config 文件夹**复制`config.yaml.example`并改名为`config.yaml`,脚本的多用户功能靠读取不同的配置文件实现,你可以创建无数个`自定义名字.yaml`,脚本会扫描**config**目录下`yaml`为拓展名的文件,并按照名称顺序依次执行。
6. 请使用 vscode/notepad++等文本编辑器打开上一步复制好的配置文件
7. **使用[获取 Cookie](#获取米游社-cookie)里面的方法来获取米游社 Cookie**
8. 将复制的 Cookie 粘贴到`config.yaml`的`cookie:" "`中(在`account`里面)
例子
> ```yaml
> cookie: 你复制的cookie
> ```9. 通过[获取Stoken](https://github.com/Womsxd/mihoyo_login) 项目获取Stoken,或请参考[Hutao文档](https://hut.ao/zh/advanced/get-stoken-cookie-from-the-third-party.html)里的方法获取Stoken (麻烦可以去关闭BBS模块mihoyobbs.enable: false)
10. 登录成功后复制 `stoken='获取到的Stoken'`里的`Stoken`,然后粘贴到`config.yaml`的`stoken: ""`中(在`account`里面)
例子
> ```yaml
> stoken: 获取到的Stoken
> ```11. 检查`config.yaml`的需求开启的功能的`enable:`的值为 true
12. 在命令提示符(cmd)/powershell,输入`python main.py`来进行执行
13. 多用户的请使用`python main_multi.py`,多用户在需要自动执行的情况下请使用`python main_multi.py autorun`
## 获取米游社 Cookie
1. 打开你的浏览器,进入**无痕/隐身模式**
2. 由于米哈游修改了 bbs 可以获取的 Cookie,导致一次获取的 Cookie 缺失,所以需要增加步骤
3. 打开`https://www.miyoushe.com/ys/`并进行登入操作
4. 按下键盘上的`F12`或右键检查,打开开发者工具,点击`Source`或`源代码`
5. 键盘按下`Ctrl+F8`或点击停用断点按钮,点击` ▌▶`解除暂停
6. 点击`NetWork`或`网络`,在`Filter`或`筛选器`里粘贴 `getUserGameUnreadCount`,同时选择`Fetch/XHR`
7. 点击一条捕获到的结果,往下拉,找到`Cookie:`
8. 复制Cookie部分除`Cookie:`的全部内容
9. 将此处的复制到的 Cookie 先粘贴到 config 文件的 Cookie 处
10. **此时 Cookie 已经获取完毕了**
## 海外版获取Cookie
1. 打开你的浏览器,进入**无痕/隐身模式**
2. 打开`https://act.hoyolab.com/bbs/event/signin/hkrpg/index.html?act_id=e202303301540311`并进行登入操作
3. 按下键盘上的`F12`或右键检查,打开开发者工具,在控制台输入:
```javascript
document.cookie
```4. 从`ltoken=....`开始复制到结尾
5. 将获取到的 Cookie 粘贴到之前获取到 OS 的 Cookie 里面
## 获取云原神的 token
1. 建议使用打开浏览器的无痕/隐私/InPrivate模式
2. 打开 [云原神网页版](https://ys.mihoyo.com/cloud/#/)
3. 按下键盘上的`F12`或右键检查,打开开发者工具,在打开后登入账号
4. 在filter里面输入`wallet/wallet/get`,选择`status`为`200`的记录
5. 点击记录,往下拉,找到`X-Rpc-Combo_token`,复制对应的值,成功获取token
## 使用 Docker 运行
Docker 的运行脚本基于 Linux 平台编写,暂未在 Win 平台测试。
将本项目 Clone 至本地后,请先按照上述步骤添加或修改配置文件。随后执行
```text
docker-compose up -d
```启动 docker 容器。
容器运行成功后可用```text
docker-compose logs -f
```命令来查看程序输出。
若需要添加配置文件或修改配置文件,可直接在主机 config 文件夹中修改,修改的内容将实时同步在容器中。
每次运行 Docker 容器后,容器内将自动按照参数执行签到活动,签到完成后容器将默认在每天上午 9:30 运行一次,如果想自行修改时间可自行编辑`docker-compose.yml`文件中的`CRON_SIGNIN`,将其修改成想运行的时间。
若想要更新容器镜像,可以参考以下命令
```text
docker-compose stop
docker-compose pull && docker-compose up -d
```## 使用 kubernetes 运行
1. 填写拷贝一份配置文件至 kube 文件夹并进入
```bash
cp config/config.yaml.example kube/config.yaml
cd kube
```2. 创建 ConfigMap 并启动服务
```bash
kubectl create cm mihoyo-conf --from-file config.yaml
kubectl apply -f deployment.yaml
```3. 查看结果
```bash
kubectl logs $(kubectl get pod -l app=mihoyo -o jsonpath="{.items[0].metadata.name}") -f --tail 40
```## 使用 python 运行(screen)
1. 将本项目 Clone 至本地后,安装好依赖直接运行`python3 server.py`
2. 在后台运行时请安装 screen
3. 使用`screen -S automhy`进入后台线程
4. Ctrl+A 组合键再按下 d 键回到主线程
5. `screen -r automhy`回到线程
6. 如果不能回到线程请先`screen -d automhy`挂起线程
### 命令窗口如下
> stop: 关闭程序
> mulit: 测试多用户签到
> single: 测试单用户签到
> reload: 重载配置文件
> mod x: mod 1 为单用户模式 mod 2 为多用户模式
> add 'yourcookie': 直接 add cookie 添加 Cookie,根据提示输入用户存档名称
> time x: 设置任务巡查时间,默认 720 分钟(12 小时)
> set user enable true(设置 user.json 的 enable 属性为 true)
> show true/false: 开启/关闭 20 秒的倒计时提示## 使用云函数运行
阿里云和腾讯云的云函数功能现已收费,请各位注意费用!
- 腾讯云
1. 下载本项目
2. 在脚本目录执行`pip3 install -r requirements.txt -t .`
3. 在本地完整运行一次。
4. 打开并登录[云函数控制台](https://console.cloud.tencent.com/scf/list)。
5. 新建云函数 - 自定义创建,函数类型选`事件函数`,部署方式选`代码部署`,运行环境选 `Python 3.10(公测版)`.
6. 提交方法选`本地上传文件夹`,并在下方的函数代码处上传整个项目文件夹。
7. 执行方法填写 `index.main_handler`,多用户请填写`index.main_handler_mulit`.
8. 展开高级配置,将执行超时时间修改为 `300 秒`,其他保持默认。
9. 展开触发器配置,选中自定义创建,触发周期选择`自定义触发周期`,并填写表达式`0 0 10 * * * *`(此处为每天上午 10 时运行一次,可以自行修改)
10. 完成,enjoy it!
- 阿里云
1. 下载本项目至本地
2. 在本地脚本目录执行`pip3 install -r requirements.txt -t .`
3. 在本地设置好config完整运行一次。(最好能一次完美过流程)
4. 打开并登录[函数计算 FC](https://fcnext.console.aliyun.com/cn-hangzhou/services)。注意左上方显示的地区,可点击切换其他地区。
5. 创建服务 (日志功能可能产生费用,建议关闭)
1. 创建函数
2. 从零开始创建
1. `请求处理程序类型:处理事件请求`
2. 推荐设置运行环境为`Python3.10`
3. `请求处理程序:index.main_handler`,多用户请填写`index.main_handler_mulit`
4. 配置触发器:触发器类型 定时触发器 异步调用。建议触发方式设为`指定时间`
5. 点击创建
3. 进入函数详情
1. 打开函数配置
2. 修改 `环境信息` - `执行超时时间` 为 300 秒。
6. 测试运行
1. 打开 `函数详情`
2. 点击`测试函数`
7. 完成## 使用青龙面板运行(V2.12+)
### 1.拉取仓库
方式 1:订阅管理
```text
名称:米游社签到
类型:公开仓库
链接:https://github.com/Womsxd/MihoyoBBSTools.git
定时类型:crontab
定时规则:2 2 28 * *
白名单:ql_main.py
依赖文件:error|mihoyo|log|push|req|set|tools|con|acc|captcha|main|gamecheckin|hoyo_checkin|competition|cloudgames|os_cloudgames
```方式 2:指令拉取
```sh
ql repo https://github.com/Womsxd/MihoyoBBSTools.git "ql_main.py" "" "error|mihoyo|log|push|req|set|tools|con|acc|captcha|main|gamecheckin|hoyo_checkin|competition|cloudgames|os_cloudgames"
```### 2.环境变量添加
在青龙面板环境变量中添加以下变量
| 名称 | 值 | 功能 |
|-----------------------------|------------------|----------------------|
| AutoMihoyoBBS_config_path | /ql/data/config/ | 设置配置文件路径(必选) |
| AutoMihoyoBBS_config_multi | 1 | 开启多用户(可选) |
| AutoMihoyoBBS_config_prefix | mhy_ | 自定义文件开头(单用户可选,多用户推荐) |
| AutoMihoyoBBS_push_project | 1 | 使用项目自带的Push,而不是青龙的 |
| AutoMihoyoBBS_push_path | /ql/data/config/ | 项目自带的推送配置文件路径 |
| AutoMihoyoBBS_push_name | push | 项目自带的推送配置文件名 |**注意!仅多用户需添加变量```AutoMihoyoBBS_config_multi```**
`AutoMihoyoBBS_push_path`和`AutoMihoyoBBS_push_name`在青龙里面仅在启用项目自带的推送后才生效
### 3.复制配置文件
**进入容器后运行以下命令**(docker exec -it ql bash)修改 ql 为你的青龙容器名字
单用户请使用以下命令复制配置文件
```sh
cp /ql/data/repo/Womsxd_MihoyoBBSTools/config/config.yaml.example /ql/data/config/config.yaml
```多用户需要注意,配置文件的名字必须以```mhy_```开头,之后的```[config*]```可以为任意字符
或通过环境变量```AutoMihoyoBBS_config_prefix```来自定义开头,如果不配置则默认```mhy_```开头```sh
cp /ql/data/repo/Womsxd_MihoyoBBSTools/config/config.yaml.example /ql/data/config/mhy_[config1].yaml
cp /ql/data/repo/Womsxd_MihoyoBBSTools/config/config.yaml.example /ql/data/config/mhy_[config2].yaml
cp /ql/data/repo/Womsxd_MihoyoBBSTools/config/config.yaml.example /ql/data/config/mhy_[config3].yaml
……
cp /ql/data/repo/Womsxd_MihoyoBBSTools/config/config.yaml.example /ql/data/config/mhy_[config*].yaml
```### 4.添加依赖
在青龙面板依赖管理中添加 httpx 及 PyYAML
### 5.编辑配置文件
单用户在配置文件内 config.yaml 中编辑信息
多用户在配置文件内 mhy_[config*].yaml 中编辑信息
***注:通知配置为青龙 config.sh 中配置**
## 使用的第三方库
~~requests~~: [GitHub](https://github.com/psf/requests) [pypi](https://pypi.org/project/requests/)
requests仅作为在httpx无法使用时的备用选择,可能未来版本会进行移除
httpx: [GitHub](https://github.com/encode/httpx) [pypi](https://pypi.org/project/httpx/)
crontab: [GitHub](https://github.com/josiahcarlson/parse-crontab) [pypi](https://pypi.org/project/crontab/)
PyYAML: [GitHub](https://github.com/yaml/pyyaml) [pypi](https://pypi.org/project/PyYAML/)
## 关于使用 Github Actions 运行
本项目**不支持**也**不推荐**使用`Github Actions`来每日自动执行!
也**不会**处理使用`Github Actions`执行有关的 issues!
## Stargazers over time
[![Stargazers over time](https://starchart.cc/Womsxd/MihoyoBBSTools.svg)](https://starchart.cc/Womsxd/MihoyoBBSTools)
## License
[MIT License](https://github.com/Womsxd/MihoyoBBSTools/blob/master/LICENSE)
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2FWomsxd%2FMihoyoBBSTools.svg?type=large)](https://app.fossa.com/projects/git%2Bgithub.com%2FWomsxd%2FMihoyoBBSTools?ref=badge_large)
## 鸣谢
[JetBrains](https://jb.gg/OpenSource)
[XiaoMiku01/miyoubiAuto](https://github.com/XiaoMiku01/miyoubiAuto)
[本项目的Contributors](https://github.com/Womsxd/MihoyoBBSTools/graphs/contributors)
还有正在使用这份程序的你