Brook GUI 文档

https://www.txthinking.com/talks/
Updated at: 2023-01-01
cloud@txthinking.com

Table of Contents

本文适用的软件

Intel Mac GUI proxy 模式, Windows GUI proxy 模式, Linux GUI proxy 模式

这个模式比较简单,会创建:

参考文章:

参考视频:

iOS/M1 Mac GUI, Android GUI, Intel Mac GUI tun 模式, Windows GUI tun 模式, Linux GUI tun 模式

所谓的互联网连接,是 IP 连接 IP,不是连接域名。所以域名会被先解析成IP再决定怎么去连接。

配置介绍

配置 支持系统 条件 描述
批量导入 iOS,Android,Mac,Windows,Linux / brook link 列表
System DNS iOS,Android,Mac,Windows,Linux / 系统 DNS. 不要 bypass 此 IP
Fake DNS iOS,Android,Mac,Windows,Linux 关闭系统/浏览器等自带的安全 DNS, 具体看下文 解析域名为 Fake IP,发起连接时会再转换为域名,然后把域名地址送到服务端进行代理,同时由服务端来负责域名解析
Block iOS,Android,Mac,Windows,Linux / Block 开关
Block Domain iOS,Android,Mac,Windows,Linux Fake DNS: 开启 域名列表,匹配的域名会被阻断解析. 域名是后缀匹配模式
Bypass iOS,Android,Mac,Windows,Linux / Bypass 开关
Bypass IP iOS,Android,Mac,Windows,Linux / CIDR 列表,匹配到的 IP 会被 bypass
Bypass Geo IP iOS,Android / 匹配到的 IP 会被 bypass. 提示: 全球 IP 变动频繁, 所以 Geo 库有时效性
Bypass Apps Android / 这些 App 会被 bypass
Bypass DNS iOS,Android,Mac,Windows,Linux / 支持普通 DNS, 比如 223.5.5.5:53, 支持 DoH, 但需要通过参数 address 指定 DoH 的地址, 比如 https://dns.alidns.com/dns-query?address=223.5.5.5%3A443 用来解析 Bypass Domain. 此 DNS 的 IP 会自动 Bypass
Bypass Domain iOS,Android,Mac,Windows,Linux Fake DNS: 开启 域名列表,匹配的域名会使用 Bypass DNS 解析来得到 IP, 最终连接是否会被 Bypass,还取决于 Bypass IP. 域名是后缀匹配模式
Hosts iOS,Android,Mac,Windows,Linux / Hosts 开关
Hosts List iOS,Android,Mac,Windows,Linux Fake DNS: 开启 给域名指定 IP, v4, v6,如果值为空效果同 Block
Programmable iOS,Android,Mac,Windows,Linux / 可编程开关
Script iOS,Android,Mac,Windows,Linux / 脚本。可以控制上面所有的功能。以及上面没有的功能,全流程控制一切,具体看下文
Log iOS,Android,Mac,Windows,Linux / 日志开关
Log View iOS,Android,Mac,Windows,Linux / 日志列表
Log View Plus iOS,Android,Mac,Windows,Linux / 日志列表,更易读,过滤条件等
MITM Log View iOS,Android,Mac,Windows,Linux / MITM 日志列表,比如 https 的请求响应,十六进制,JSON,图片等
Proxy / Tun Mac,Windows,Linux / 选择 proxy 模式 还是 tun 模式
深色主题 iOS,Android,Mac,Windows,Linux / 暗黑模式 模式
快捷方式 iOS,Android,Mac,Windows,Linux / 暗黑模式 模式

Programmable

Brook GUI 会在不同时机向脚本传入不同的全局变量,脚本只需要将处理结果赋值到全局变量 out 即可

完全掌控你自己的网络

传入变量介绍

变量 类型 条件 时机 描述 out 类型
in_guiconfig map / 开启之前 用以覆盖 GUI 的配置 map
in_dnsquery map FakeDNS: 开启 当 DNS 查询发生时 脚本可以决定如何处理此请求 map
in_address map / 当要连接某地址时 脚本可以决定如何进行连接 map
in_httprequest map / 当有 HTTP(S)请求传入时 脚本可以决定如何处理此请求 map
in_httprequest,in_httpresponse map / 当有 HTTP(S)响应传入时 脚本可以决定如何处理此响应 map

in_guiconfig

Key 类型 描述
_ bool 向未来兼容,可忽略此 key

out, 如果是 error 类型会被记录在日志。如果不是 map 类型则会被忽略, 如果是map那么明确指定每一个配置项

Key 类型 描述
systemdns4 string System DNS v4
systemdns6 string System DNS v6
fakedns bool Fake DNS 开关
block bool GUI Block 开关
bypass bool GUI Bypass 开关
bypassdns4 string Bypass DNS v4
bypassdns6 string Bypass DNS v6
hosts bool GUI Hosts 开关

in_dnsquery

Key 类型 描述 示例
domain string 域名 google.com
type string 查询类型 A

out, 如果是 error 类型会被记录在日志。如果不是 map 类型则会被忽略

Key 类型 描述 示例
block bool 是否 Block, 默认 false. 与 GUI Block Domain 是或的关系 false
ip string 直接指定 IP,仅当 typeA/AAAA有效 1.2.3.4
forcefakedns bool 忽略 GUI Bypass Domain,使用 Fake DNS 来处理,仅当 typeA/AAAA有效,默认 false false
system bool 使用 System DNS 来解析,默认 false false
bypass bool 是否 Bypass, 默认 false, 如果为 true 则使用 Bypass DNS 来解析. 与 GUI Bypass Domain 是或的关系 false

in_address

Key 类型 描述 示例
network string 即将发起连接网络,取值 tcp/udp tcp
ipaddress string IP 类型的地址,与 domainaddress 只会存在一个。注意这两个之间没有任何关系 1.2.3.4:443
domainaddress string 域名类型的地址,因为 FakeDNS 我们这里才能拿到域名地址 google.com:443

out, 如果是 error 类型会被记录在日志。如果不是 map 类型则会被忽略

Key 类型 描述 示例
block bool 是否 Block, 默认 false false
ipaddress string IP 类型地址,重写目的地 1.2.3.4:443
ipaddressfrombypassdns string 使用 Bypass DNS 获取AAAAA IP 并重写目的地, 仅当 domainaddress 存在时有效,取值 A/AAAA A
bypass bool 仅在 iOS, Android 有效。是否 Bypass, 默认 false. 如果为 true 并且是 domainaddress, 那么必须指定 ipaddressipaddressfrombypassdns. 与 GUI Bypass IP 是或的关系 false
mitm bool 是否进行 MITM, 默认 false. 仅当 networktcp 时有效. 需要安装 CA,看下文介绍 false
mitmprotocol string 需要明确指定 MITM 协议, 取值 http/https https
mitmcertdomain string MITM 证书域名,默认从domainaddress里取。如果是 ipaddressmitmtruemitmprotocolhttps 那么必须明确指定 example.com
mitmwithbody bool 是否操作 http body,默认 false. 会将请求和响应的 body 读取到内存里和脚本交互。iOS 50M 总内存限制可能会杀进程 false
mitmautohandlecompress bool 和脚本交互时是否自动解压缩 http body, 默认 false false
mitmclienttimeout int Timeout for MITM talk to server, second, default 0 0
mitmserverreadtimeout int Timeout for MITM read from client, second, default 0 0
mitmserverwritetimeout int Timeout for MITM write to client, second, default 0 0

in_httprequest

Key 类型 描述 示例
URL string URL https://example.com/hello
Method string HTTP method GET
Body bytes HTTP request body /
... string 其他字段均为 HTTP header /

out, 必须设置为一个 request 或 response

in_httpresponse

Key 类型 描述 示例
StatusCode int HTTP status code 200
Body bytes HTTP response body /
... string 其他字段均为 HTTP header /

out, 必须设置为一个 response

如何写 Tengo 脚本

Tengo Language Syntax

Library

示例

https://github.com/txthinking/bypass/blob/master/example_script.tengo

如何调试脚本

为什么以及如何关闭系统和浏览器安全 DNS

因为开启后,FakeDNS 就拿不到域名了. 所以我们要关闭它:

其他系统和软件,请自行查找是否存在以及如何关闭

安装 CA

https://txthinking.github.io/ca/ca.pem

iOS

https://www.youtube.com/watch?v=HSGPC2vpDGk

Android

Android 分系统 CA 和用户 CA,必须要 ROOT 后安装到系统 CA 里

macOS

nami install mad ca.txthinking
sudo mad install --ca ~/.nami/bin/ca.pem

Windows

打开 GitBash

nami install mad ca.txthinking

然后用管理员打开 GitBash

mad install --ca ~/.nami/bin/ca.pem

注意 GitBash 或 Firefox 等软件可能不读取系统 CA,安装后可以用系统 Edge 浏览器测试

Apple 推送问题

要接收推送,Apple Server 只允许 Ethernet, cellular data, Wi-Fi 连接. 所以你需要 Bypass 掉相关域名和 IP. 参考链接

其他资源