# whistle-client
**Repository Path**: kbynt/whistle-client
## Basic Information
- **Project Name**: whistle-client
- **Description**: No description available
- **Primary Language**: JavaScript
- **License**: MIT
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2025-01-16
- **Last Updated**: 2025-01-16
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# Whistle 客户端
Whistle 客户端是基于 [Whistle (命令行版本)](https://github.com/avwo/whistle) + [Electron](https://github.com/electron/electron) 开发的支持 Mac 和 Windows 的客户端,它不仅保留了命令行版本的除命令行以外的所有功能,且新增以下功能代替复杂的命令行操作,让用户使用门槛更低、操作更简单:
1. 无需安装 Node,客户端下载安装后即可使用
2. 打开客户端自动设置系统代理(可以通过下面的 `Proxy Settings` 关闭该功能,`v1.2.4` 版本开始默认不自动设置系统代理,需要通过 `Proxy Settings` 设置面板开启)
3. 通过界面手动开启或关闭系统代理(相当于命令行命令 `w2 proxy port` 或 `w2 proxy 0`)
4. 通过界面设置系统代理白名单(相当于命令行命令 `w2 proxy port -x domains`)
5. 通过界面修改代理的端口(客户端默认端口为 `8888`)
6. 通过界面新增或删除 Socks5 代理(相当于命令行启动时设置参数 `--socksPort`)
7. 通过界面指定监听的网卡地址(相当于命令行启动时设置参数 `-H`)
8. 通过界面设置代理的用户名和密码(相当于命令行启动时设置参数 `-n xxx -w yyy`)
9. 通过界面重启 Whistle
10. 通过界面安装 Whistle 插件
# 安装或更新
Whistle 客户端目前只支持 Mac 和 Windows 系统,如果需要在 Linux、 Docker、服务端等其它环境使用,可以用命令行版本:[https://github.com/avwo/whistle](https://github.com/avwo/whistle)。
安装和更新的方法是一样的,下面以安装过程为例:
#### Windows
1. 下载名为 [Whistle-v版本号-win-x64.exe](https://github.com/avwo/whistle-client/releases) 最新版本号的安装包
> 没有管理员权限的用户可以下载 [Whistle-user-installer-v版本号-win-x64.exe](https://github.com/avwo/whistle-client/releases) 用户版本安装包,跟默认版本的区别是 **User Installer** 不支持伪协议(`whistle://client`)
2. 打开安装包可能会弹出以下对话框,点击 `是` 、`确定`、`允许访问` 按钮即可
> 一些公司的软件可能会把 Whistle.exe 以及里面让系统代理设置立即生效的 refresh.exe 文件误认为问题软件,直接点击允许放过即可,如果还有问题可以跟公司的安全同事沟通下给软件加白
#### Mac
Mac 有 Intel 和 M1 两种芯片类型,不同类型芯片需要下载不同的安装包,其中:
1. M1 Pro、M2 Pro 等 M1 芯片的机型下载名为 [Whistle-v版本号-mac-arm64.dmg](https://github.com/avwo/whistle-client/releases) 的最新版本号的安装包
2. 其它非 M1 芯片机型下载名为 [Whistle-v版本号-mac-x64.dmg](https://github.com/avwo/whistle-client/releases) 的最新版本号的安装包
下载成功点击开始安装(将 Whistle 图标拖拽到 Applications / 应用程序):
安装完成在桌面上及应用程序可以看到 Whistle 的图标:
点击桌边图标打开 Whistle,第一次打开时可能遇到系统弹窗,可以在“系统偏好设置”中,点按“安全性与隐私”,然后点按“通用”。点按锁形图标,并输入您的密码以进行更改。在“允许从以下位置下载的 App”标题下面选择“App Store”,或点按“通用”面板中的“仍要打开”按钮:
> 打开客户端会自动设置系统代理,第一次可能需要用户输入开机密码
> 一些公司的软件可能会把客户端里面引用的设置代理的 whistle 文件误认为问题软件,直接点击允许放过即可,如果还有问题可以跟公司的安全同事沟通下给软件加白
# 基本用法
1. 顶部 `Whistle` 菜单
- Proxy Settings
- Install Root CA
- Check Update
- Set As System Proxy
- Start At Login
- Restart
- Quit
2. 安装插件
3. 其它功能
## 顶部菜单
1. `Proxy Settings`:见下方 Proxy Settings
2. `Install Root CA`:安装根证书
3. `Check Update`:查看是否有新版本
4. `Set As System Proxy`:设置系统代理
5. `Start At Login`:是否开机自动启动 Whistle 客户端
6. `Restart`:重启客户端
7. `Quit`:退出客户端
#### Proxy Settings
1. `Proxy Port`:必填项,代理端口,默认为 `8888`
2. `Socks Port`:新增 Socksv5 代理端口
3. `Bound Host`:指定监听的网卡
4. `Proxy Auth`:设置用户名和密码对经过代理的请求进行鉴权
5. `Bypass List`:不代理的白名单域名,支持以下三种格式:
- IP:`127.0.0.1`
- 域名:`www.test.com`
- 通配符:`*.test.com`(这包含 `test.com` 的所有子代域名)
6. `Use whistle's default storage directory`:存储是否切回命令行版本的目录,这样可以保留之前的配置数据(勾选后要停掉命令行版本,否则配置可能相互覆盖)
#### Install Root CA
安装系统根证书,安装根证书后可能因为某些客户端不支持自定义证书导致请求失败,可以通过在 `Proxy Settings` 的 `Bypass List` 设置以下规则(空格或换行符分隔):
``` txt
*.cdn-apple.com *.icloud.com .icloud.com.cn *.office.com *.office.com.cn *.office365.cn *.apple.com *.mzstatic.com *.tencent.com *.icloud.com.cn
```
如果还未完全解决问题,可以把抓包列表出现的以下有问题的请求域名填到 `Bypass List` :
#### Check Update
点击查看是否有新版本,如果有最新版本建议立即升级。
#### Set As System Proxy
> 托盘图标右键也支持该功能
开启或关闭系统代理,如果想在客户端启动的时候是否自动设置系统代理需要通过 `Proxy Settings` 的 `Set system proxy at startup` 设置。
#### Restart
重启客户端。
#### Quit
退出客户端,退出客户端会自动关闭系统代理。
## 安装插件
打开界面左侧的 `Plugins` Tab,点击上方 `Install` 按钮,输入要安装插件的名称(多个插件用空格或换行符分隔),如果需要特殊的 npm registry 可以手动输入 `--registry=xxx` 或在对话框下方选择之前使用过的 npm registry。
如输入:
``` txt
whistle.script whistle.vase --registry=https://registry.npmmirror.com
```
> 后面的版本会提供统一的插件列表页面,用户只需选择安装即可,无需手动输入插件包名
## 其他功能
除了上述功能,其它非命令行操作跟命令行版的 Whistle 一样,详见:https://github.com/avwo/whistle
# 常见问题
#### 1. 设置系统代理后,某些客户端(如:outlook、word 等)出现请求异常问题的原因及解决方法
在 `Proxy Settings` 的 `Bypass List` 设置以下规则:
``` txt
*.cdn-apple.com *.icloud.com .icloud.com.cn *.office.com *.office.com.cn *.office365.cn *.apple.com *.mzstatic.com *.tencent.com *.icloud.com.cn
```
如果还未完全解决,可以把抓包列表出现的以下有问题的请求域名填到 `Bypass List` :
#### 2. 如何更新客户端?
打开左上角 Whistle 菜单 / Check Update 按钮,检查是否有最新版本,如果有按更新指引操作,或者直接访问 https://github.com/avwo/whistle-client/releases 下载系统相关的版本
#### 3. 如何同步之前的数据?
Whistle 客户端默认使用独立的目录,如果要复用之前命令行版本的目录,可以通过 `Proxy Settings` 的 `Use whistle's default storage directory` 切回命令行的默认目录:
> 要确保同一目录只有一个实例,否则会导致配置相互覆盖
如果想让客户端保持独立的目录,也可以通过以下方式手动同步数据:
1. 手动同步 Rules:从老 Whistle / Rules / Export / ExportAll 导出规则后,再通过 Whistle 客户端 / Rules / Import 导入
2. 手动同步 Values:从老 Whistle / Values / Export / ExportAll 导出规则后,再通过 Whistle 客户端 / Values / Import 导入
3. 手动同步 Plugins:通过 Plugins:从老 Whistle / Plugins / ReinstallAll / Copy 按钮复制所有插件名称,再通过客户端 Plugins / Install / 粘贴 / Install 按钮安装
# License
[MIT](./LICENSE)