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