
多功能跨平台网络工具Brook提供灵活控制
Brook是一款跨平台网络工具,支持iOS、Android、Mac、Windows、Linux和OpenWrt 等多种操作系统。它提供Fake DNS功能和可编程脚本接口,使用户能够精细控制网络请求和管理。Brook适用于各种网络环境,可用于优化网络性能和管理复杂的网络需求。
A cross-platform programmable network tool.
❤️ Shiliew - A network app designed for those who value their time
bash <(curl https://bash.ooo/nami.sh)
nami install brook
brook server -l :9999 -p hello
| iOS | Android | Mac | Windows | Linux | OpenWrt |
|---|---|---|---|---|---|
![]() | ![]() | ![]() | ![]() | ![]() | ![]() |
| / | / | App Mode | How | How | How |
You may want to use
brook linkto customize some parameters
Brook GUI will pass different global variables to the script at different times, and the script only needs to assign the processing result to the global variable out
Before discussing the GUI client, let's first talk about the command line client brook. As we know, after you have deployed the server, you can use the command line client brook to create a local socks5 proxy or http proxy on your machine, and then configure it in your system proxy settings or in your browser to use this proxy. However:
For the specifics of socks5 and http proxy, you can read this article.
The GUI client does not use socks5 and http proxy mode, so there is no issue with some software not using the system proxy. Instead, it uses a virtual network card to take over the entire system's network, including UDP-based http3. Moreover, Brook allows us to control network requests programmatically, so it is necessary to have basic knowledge of network requests.
Note: When we talk about addresses, we mean addresses that include the port number, such as a domain address:
google.com:443, or an IP address:8.8.8.8:53
google.com:4438.8.8.8:53, to inquire about the IP of google.com
google.com, such as 1.2.3.4, to the app1.2.3.4:4431.2.3.4:443In the above process, the app actually makes two network requests: one to the IP address 8.8.8.8:53 and another to the IP address 1.2.3.4:443. In other words, the domain name is essentially an alias for the IP, and must obtain the domain's IP to establish a connection.
Brook has a Fake DNS feature, which can parse the domain name out of the query requests that an app sends to the system DNS and decide how to respond to the app.
google.com:4438.8.8.8:53, to inquire about the IP of google.com8.8.8.8:53. <mark>This will trigger the in_dnsquery variable, carrying information such as domain</mark>
240.0.0.1240.0.0.1:443240.0.0.1:443240.0.0.1:443, discovers that this is a fake IP, and will convert the fake IP address back to the domain address google.com:443. <mark>This will trigger the in_address variable, carrying information such as domainaddress</mark>
google.com:443 to the Brook Servergoogle.com, such as receiving 1.2.3.41.2.3.4:4431.2.3.4:443 and returns the data to the Brook clientHowever, if the following situations occur, the domain name will not/cannot be parsed, meaning that the Brook client will not/cannot know what the domain name is and will treat it as a normal request sent to an IP address:
To avoid the ineffectiveness of Fake DNS, please refer to this article.
google.com:4438.8.8.8:53, to inquire about the IP of google.com8.8.8.8:53. <mark>This will trigger the in_address variable, carrying information such as ipaddress</mark>
8.8.8.8:53 to the Brook Server8.8.8.8:53 and returns the result, such as 1.2.3.4, to the Brook client1.2.3.4:4431.2.3.4:4431.2.3.4:443. <mark>This will trigger the in_address variable, carrying information such as ipaddress</mark>
1.2.3.4:443 to the Brook Server1.2.3.4:443 and returns the data to the Brook clientgoogle.com:4438.8.8.8:443, to inquire about the IP of google.com8.8.8.8:443. <mark>This will trigger the in_address variable, carrying information such as ipaddress</mark>
8.8.8.8:443 to the Brook Server8.8.8.8:443, and returns the result, such as 1.2.3.4, to the Brook client1.2.3.4:4431.2.3.4:4431.2.3.4:443. <mark>This will trigger the in_address variable, carrying information such as ipaddress</mark>
1.2.3.4:443 to the Brook Server1.2.3.4:443 and returns the data to the Brook clientTo avoid the ineffectiveness of Fake DNS, please refer to this article.
in_brooklinks variable is triggered:
in_dnsquery variable is triggered, you can process as needed, such as:
in_address variable is triggered, you can process as needed, such as:
in_httprequest and in_httpresponse.in_httprequest variable is triggered, you can process as needed, such as:
in_httpresponse variable is triggered, you can process as needed, such as:
For detailed information on the properties and responses of variables, please refer to the following content.
| variable | type | condition | timing | description | out type |
|---|---|---|---|---|---|
| in_brooklinks | map | / | Before connecting | Predefine multiple brook links, and then programmatically specify which one to connect to | map |
| in_dnsquery | map | FakeDNS: On | When a DNS query occurs | Script can decide how to handle this request | map |
| in_address | map | / | When connecting to an address | script can decide how to connect | map |
| in_httprequest | map | / | When an HTTP(S) request comes in | the script can decide how to handle this request | map |
| in_httprequest,in_httpresponse | map | / | when an HTTP(S) response comes in | the script can decide how to handle this response | map |
| Key | Type | Description | Example |
|---|---|---|---|
| _ | bool | meaningless | true |
out, ignored if not of type map
| Key | Type | Description | Example |
|---|---|---|---|
| ... | ... | ... | ... |
| custom name | string | brook link | brook://... |
| ... | ... | ... | ... |
| Key | Type | Description | Example |
|---|---|---|---|
| domain | string | domain name | google.com |
| type | string | query type | A |
| appid | string | App ID or path | com.google.Chrome.helper |
| interface | string | network interface. Mac only | en0 |
out, if it is error type will be recorded in the log. Ignored if not of type map
| Key | Type | Description | Example |
|---|---|---|---|
| block | bool | Whether Block, default false | false |
| ip | string | Specify IP directly, only valid when type is A/AAAA | 1.2.3.4 |
| system | bool | Resolve by System DNS, default false | false |
| bypass | bool | Resolve by Bypass DNS, default false | false |
| brooklinkkey | string | When need to connect the Server,instead, connect to the Server specified by the key in_brooklinks | custom name |
| Key | Type | Description | Example |
|---|---|---|---|
| network | string | Network type, the value tcp/udp | tcp |
| ipaddress | string | IP type address. There is only of ipaddress and domainaddress. Note that there is no relationship between these two | 1.2.3.4:443 |
| domainaddress | string | Domain type address, because of FakeDNS we can get the domain name address here | google.com:443 |
| appid | string | App ID or path | com.google.Chrome.helper |
| interface | string | network interface. Mac only | en0 |
out, if it is error type will be recorded in the log. Ignored if not of type map
| Key | Type | Description | Example |
|---|---|---|---|
| block | bool | Whether Block, default false | false |
| ipaddress | string | IP type address, rewrite destination | 1.2.3.4:443 |
| ipaddressfrombypassdns | string | Use Bypass DNS to obtain A or AAAA IP and rewrite the destination, only valid when domainaddress exists, the value A/AAAA | A |
| bypass | bool | Bypass, default false. If true and domainaddress, then ipaddress or ipaddressfrombypassdns must be specified | false |
| mitm | bool | Whether to perform MITM, default false. Only valid when network is tcp. Need to install CA, see below | false |
| mitmprotocol | string | MITM protocol needs to be specified explicitly, the value is http/https | https |
| mitmcertdomain | string | The MITM certificate domain name, which is taken from domainaddress by default. If ipaddress and mitm is true and mitmprotocol is https then must be must be specified explicitly | example.com |
| mitmwithbody | bool | Whether to manipulate the http body, default false. will read the body of the request and response into the memory and interact with the script. iOS 50M total memory limit may kill process | false |
| mitmautohandlecompress | bool | Whether to automatically decompress the http body when interacting with the script, default false | false |
| mitmclienttimeout | int | Timeout for MITM talk to server, |


全球首个AI音乐社区
音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创 作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。


一站式搞定所有学习需求
不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。


为AI短剧协作而生
专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。


能听懂你表达的视频模型
Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。


国内直接访问,限时3折
输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文 字生图、图生图。官网价格限时3折活动


职场AI,就用扣子
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!


多风格AI绘画神器
堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。