diff --git a/README.md b/README.md new file mode 100644 index 0000000..3b75f28 --- /dev/null +++ b/README.md @@ -0,0 +1,329 @@ +![logo](img/smsboom-logo.png) + +![test](img/test2.gif) + +## 三件事 + +1. 原作者 *@whalefell* 為保障自身安全及規避風險,於 `2022/7/6` 將本倉庫移交給我.至此,本倉庫所有事務與原作者無關. +2. 介於本項目在簡中 **GitHub** 圈影響較大,請大家遵守自己所在國家地區的相關法律,**違反法律者與開發者無關**. +3. 請大家理智甄別,獨立思考. + + +> 简体中文: +> 1. 原作者 *@whalefell* 为保障自身安全及规避风险,于 `2022/7/6` 将本仓库移交给我.至此,本仓库所有事务与原作者无关. +> 2. 介于本项目在简中 **GitHub** 圈影响较大,请大家遵守自己所在国家地区的相关法律,**违反法律者与开发者无关**. +> 3. 请大家理智甄别,独立思考. + +## 免责声明 + +1. 若使用者滥用本项目,本人 **无需承担** 任何法律责任. +2. 本程序仅供娱乐,源码全部开源,**禁止滥用** 和二次 **贩卖盈利**. **禁止用于商业用途**. + +## Feature + +1. 通过自定义 `api.json` 的方式定义接口. +2. 支持关键字替换. **时间戳** `[timestamp]` **手机号** `[phone]` +3. 多线程/异步 请求. +4. 通过 Flask 提供网页测试/添加接口. +5. 友好的命令行参数支持. +6. 采用方便的 pipenv 包管理. +7. 通过代理调用短信接口, 支持http, socks4, socks5代理. +8. 使用随机的User-Agent. +9. 可指定轰炸次数, 轰炸间隔时间. + +## Quick Start + +### 适用于小白 + +✨本项目已经使用 `pyinstaller` 打包成 `EXE` 可执行文件!免去部署 Python 环境的烦恼,适合用于小白白. + +🔨作者的打包环境为: `Windows 10 x64 Python3.8` 如果 Windows 系统不是 **Windows 10 64位** 版本,**可能会运行失败**! 如果出现异常报错请截图发 Issue. + +1. 下载 EXE 可执行文件 + 请移步到项目的 [release页](https://github.com/AdminWhaleFall/SMSBoom/releases) 下载 + + > 若遇到国内网络环境下载不下来,请参见 [https://github.do/](https://github.do/) 等加速镜像. + +2. 运行 + + 1. 在任意盘(**除C盘外**)中新建一个文件夹.将程序移动到其中. e.g. + ![](https://cdn.jsdelivr.net/gh/AdminWhaleFall/SMSBoom@master/img/e.g.1.png) + + 2. `Win`+`R` 打开cmd.输入存放的盘符.例如: `E:` 然后cd到文件夹,例如 `cd SMS` + ![](https://cdn.jsdelivr.net/gh/AdminWhaleFall/SMSBoom@master/img/cmd1.png) + + 3. 确认 cmd 路径是 EXE 所在路径后,cmd 输入:`smsboom_pyinstall.exe`,若出现命令提示,则说明脚本已正常运行. + ![](https://cdn.jsdelivr.net/gh/AdminWhaleFall/SMSBoom@master/img/cmd2.png) + + 4. 使用前必须更新一遍最新接口 + ```shell + smsboom_pyinstall.exe update + ``` + > 若更新接口出现错误 `ssl_`,请参见 [issue](https://github.com/AdminWhaleFall/SMSBoom/issues/2) **关闭代理软件**再 update. + + 5. [对代理设置的说明](https://github.com/WhaleFell/SMSBoom#%E4%BD%BF%E7%94%A8%E4%BB%A3%E7%90%86), 小白可以暂时不看 + + 6. 传递参数,命令示例: + + 启动64个线程,轰//炸一个人的手机号(198xxxxxxxx),只轰//炸一波。 + + ```shell + smsboom_pyinstall.exe run -t 64 -p 198xxxxxxxxx + ``` + + 启动64个线程,轰//炸一个人的手机号(19xxxxxxx),启动循环轰//炸, 轮番轰//炸60次 + + ```shell + smsboom_pyinstall.exe run -t 64 -p 198xxxxxxxxx -f 60 + ``` + + 启动64个线程,轰//炸一个人的手机号(19xxxxxxx),启动循环轰//炸, 轮番轰//炸60次, 每次间隔30秒 + + ```shell + smsboom_pyinstall.exe run -t 64 -p 198xxxxxxxxx -f 60 -i 30 + ``` + + 启动64个线程,轰//炸一个人的手机号(19xxxxxxx),启动循环轰//炸, 轮番轰//炸60次, 每次间隔30秒, 开启代理列表进行轰炸 + + ```shell + smsboom_pyinstall.exe run -t 64 -p 198xxxxxxxxx -f 60 -i 30 -e + ``` + + 启动64个线程,轰//炸多个人的手机号(138xxx,139xxxx),启动循环轰//炸, 轮番轰炸60次, 每次间隔30秒, 开启代理列表进行轰炸 + + ```shell + smsboom_pyinstall.exe run -t 64 -p 138xxxxxxxx -p 139xxxxxxxx -f 60 -i 30 -e + ``` + + +### 适用于大佬 + +#### 下载项目 + +- 方法一:使用Git: + +```shell +git clone https://github.com/AdminWhaleFall/SMSBoom.git/ +``` + +> 墙国加速 +> +> ```shell +> git clone https://github.do/https://github.com/AdminWhaleFall/SMSBoom.git +> ``` + +- 方法二:点击下载[项目压缩包](https://github.com/AdminWhaleFall/SMSBoom/archive/refs/heads/master.zip)并解压. + +#### 配置环境 + +**前提条件:** 请确保自己的电脑有 `python3.x` 的环境,推荐使用 `3.8` 及以上! + +方案一: 有 `Python3.8` 环境的可以使用 `pipenv` 工具. + +1. 安装 pipenv 包管理工具. +```shell +pip install pipenv +``` + +2. 为项目构建虚拟环境. +```shell +pipenv install # 仅使用轰//炸功能 +pipenv install --dev # 使用 webui 调试接口功能. +``` + +3. 尝试运行 smsboom.py +```shell +pipenv shell # 激活虚拟环境 +python smsboom.py # linux +``` + +若无报错,输出帮助信息,则说明环境已经正确安装。若报错请使用方案二 + +方案二: 只有 `Python3.X` 环境的需要使用原生 `pip` 工具. + +1. 安装所需要的库 +```shell +pip install -r requirements.txt # 仅使用轰//炸 +pip install -r requirements-dev.txt # 使用 webui +``` + +2. 尝试运行 smsboom.py +```shell +python smsboom.py +``` + +若无报错,输出帮助信息,则说明环境已经正确安装。 + +#### 使用 Docker 运行 + +**前提条件:** 请确保当前环境已安装 [Docker](https://docs.docker.com/get-docker/). + +1. 构建镜像 + +```shell +docker build -t whalefell/smsboom . +``` + +2. 尝试运行 + +```shell +docker run --rm whalefell/smsboom:latest --help + +Usage: smsboom.py [OPTIONS] COMMAND [ARGS]... + +Options: + --help Show this message and exit. + +Commands: + asyncrun 以最快的方式请求接口(真异步百万并发) + onerun 单线程(测试使用) + run 传入线程数和手机号启动轰炸,支持多手机号 + update 从 github 获取最新接口 +``` + +#### 运行 + +若使用虚拟环境,请先激活. `pipenv shell` + +```shell +# 输出帮助信息 +python smsboom.py --help + +Usage: smsboom.py [OPTIONS] COMMAND [ARGS]... +Options: +--help Show this message and exit. +Commands: +run 传入线程数和手机号启动轰//炸,支持多手机号 +update 从 github 获取最新接口 +``` + +- 启动轰//炸 + +帮助信息: + +```shell +python smsboom.py run --help + +Usage: smsboom.py run [OPTIONS] + +传入线程数和手机号启动轰//炸,支持多手机号 + +Options: +-t, --thread INTEGER 线程数(默认64) +-p, --phone TEXT 手机号,可传入多个再使用-p传递 [required] +-f, --frequency INTEGER 执行次数(默认1次) +-i, --interval INTEGER 间隔时间(默认60s) +-e, --enable_proxy BOOLEAN 开启代理(默认关闭) +--help Show this message and exit. +``` + +### 使用代理 + +本项目不能通过API自动获取代理, 你可以从下面的免费代理网站中手动获取代理, 或是选择使用自己的代理, 或是不使用代理. + +> [https://proxyscrape.com/free-proxy-list](https://proxyscrape.com/free-proxy-list) + +> [https://openproxy.space/list](https://openproxy.space/list) + +将代理添加到 `http_proxy.txt` `socks4_proxy.txt` `socks5_proxy.txt` 三个文件中, 命令参数添加 `-e` 执行即可. + +### 命令示例 + +启动64个线程,轰//炸一个人的手机号(198xxxxxxxx),只轰//炸一波。 + +```shell +python smsboom.py run -t 64 -p 198xxxxxxxx +``` + +启动64个线程,轰//炸一个人的手机号(198xxxxxxxx),启动循环轰//炸, 轮番轰//炸60次 + +```shell +python smsboom.py run -t 64 -p 198xxxxxxxx -f 60 +``` + +启动64个线程,轰//炸一个人的手机号(198xxxxxxxx),启动循环轰//炸, 轮番轰//炸60次, 每次间隔30秒 + +```shell +python smsboom.py run -t 64 -p 198xxxxxxxx -f 60 -i 30 +``` + +启动64个线程,轰//炸一个人的手机号(198xxxxxxxx),启动循环轰//炸, 轮番轰//炸60次, 每次间隔30秒, 开启代理列表进行轰炸 + +```shell +python smsboom.py run -t 64 -p 198xxxxxxxx -f 60 -i 30 -e +``` + +启动64个线程,轰//炸多个人的手机号(198xxxxxxxx,199xxxxxxxx),启动循环轰//炸, 轮番轰炸60次, 每次间隔30秒, 开启代理列表进行轰炸 + +```shell +python smsboom.py run -t 64 -p 198xxxxxxxx -p 199xxxxxxxx -f 60 -i 30 -e +``` + +## Development + +程序提供接口调试工具,但目前还不完善,欢迎前端大佬 PR。 +调试工具以 `Flask` 为后端,`vue` 为前端,实现前后端分离。 +目前只有测试接口,添加接口的功能。 + +### Flask 前端调试 + +> **前提是已经根据前文 Quick Start 的方式安装好 pipenv 环境** + +```shell +pipenv shell # 激活虚拟环境 +python run_flask_app.py start -p 9090 # 监听9090端口 +``` + +**运行帮助:** +```shell +Usage: run_flask_app.py [OPTIONS] COMMAND [ARGS]... + +Options: + --help Show this message and exit. + +Commands: + init 初始化数据库 + json2sqlite 将json数据转为sqlite数据库 + sqlite2json 将sqlite数据转为json + start 启动 flask app +``` + +```shell +Usage: run_flask_app.py start [OPTIONS] + + 启动 flask app + +Options: + -h, --host TEXT 监听地址 + -p, --port INTEGER 监听端口 + --help Show this message and exit. +``` + +默认监听 *0.0.0.0:9090* 地址,浏览器访问[http://127.0.0.1:9090/admin/](http://127.0.0.1:9090/admin/)若无意外,就可以出现前端调试界面。 + +![](img/webui-test.png) +![](img/webui-test-2.png) + +## 赞助 +[爱发电🔗](https://afdian.net/@smsboom) + +> 赞助的金额将用于我每月治疗 **抑/郁症** 的支出.谢谢大家的支持和鼓励! **比心ing** + + +## Star ♥ 趋势图 + + + +## ✨讨论 + +欢迎加入讨论对项目提出问题和建议!!!mua! + +### 企鹅🐧群 +> 企鹅群不允许讨论相关敏感信息!违者上飞机票✈ + +2022/7/6 停止运作. + +### Telegram Channel (TG群组) +> 涉及敏/感信息,政/治,民/主运动话题请到 **TG群聊** + +[SMSBoomPro](https://t.me/SMSBoomPro)