2023-09-20 20:28:00 +08:00
|
|
|
|
# UA2F
|
|
|
|
|
|
2023-10-22 16:19:41 +08:00
|
|
|
|
[](https://github.com/Zxilly/UA2F/actions/workflows/codeql.yml)
|
|
|
|
|
[](https://github.com/Zxilly/UA2F/actions/workflows/ci.yml)
|
2023-09-20 20:28:00 +08:00
|
|
|
|
|
2023-10-20 23:35:41 +08:00
|
|
|
|
参照 [博客文章](https://learningman.top/archives/304) 完成操作
|
2023-09-20 20:28:00 +08:00
|
|
|
|
|
|
|
|
|
如果遇到了任何问题,欢迎提出 Issues,但是更欢迎直接提交 Pull Request
|
|
|
|
|
|
|
|
|
|
> 由于新加入的 CONNMARK 影响,编译内核时需要添加 `NETFILTER_NETLINK_GLUE_CT` flag
|
|
|
|
|
|
|
|
|
|
## uci command
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
# 启用 UA2F
|
|
|
|
|
uci set ua2f.enabled.enabled=1
|
|
|
|
|
|
|
|
|
|
# 可选的防火墙配置选项
|
|
|
|
|
# 是否自动添加防火墙规则
|
|
|
|
|
uci set ua2f.firewall.handle_fw=1
|
|
|
|
|
|
|
|
|
|
# 是否尝试处理 443 端口的流量, 通常来说,流经 443 端口的流量是加密的,因此无需处理
|
|
|
|
|
uci set ua2f.firewall.handle_tls=1
|
|
|
|
|
|
|
|
|
|
# 是否处理微信的流量,微信的流量通常是加密的,因此无需处理。这一规则在启用 nftables 时无效
|
|
|
|
|
uci set ua2f.firewall.handle_mmtls=1
|
|
|
|
|
|
|
|
|
|
# 是否处理内网流量,如果你的路由器是在内网中,且你想要处理内网中的流量,那么请启用这一选项
|
|
|
|
|
uci set ua2f.firewall.handle_intranet=1
|
|
|
|
|
|
2023-10-20 23:35:41 +08:00
|
|
|
|
# 使用自定义 User-Agent
|
|
|
|
|
uci set ua2f.main.custom_ua="Test UA/1.0"
|
|
|
|
|
|
2023-09-20 20:28:00 +08:00
|
|
|
|
# 应用配置
|
|
|
|
|
uci commit ua2f
|
|
|
|
|
|
|
|
|
|
# 开机自启
|
|
|
|
|
service ua2f enable
|
|
|
|
|
|
|
|
|
|
# 启动 UA2F
|
|
|
|
|
service ua2f start
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 自定义 User-Agent
|
|
|
|
|
|
2023-10-20 23:35:41 +08:00
|
|
|
|
### 集成到二进制
|
|
|
|
|
|
2023-09-20 20:28:00 +08:00
|
|
|
|
`make menuconfig` 后,使用 option 设置
|
|
|
|
|
|
|
|
|
|

|
|
|
|
|
|
|
|
|
|
`UA2F_CUSTOM_UA` 的值必须是一个字符串,且长度不超过 `(65535 + (MNL_SOCKET_BUFFER_SIZE / 2))` 字节。 `MNL_SOCKET_BUFFER_SIZE` 的值通常为 8192。
|
|
|
|
|
|
2023-10-20 23:35:41 +08:00
|
|
|
|
### 使用 uci 设置
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
uci set ua2f.main.custom_ua="Test UA/1.0"
|
|
|
|
|
uci commit ua2f
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
> UA2F 不会修改包的大小,因此即使自定义了 User-Agent, 运行时实际的 User-Agent 会是一个从 custom ua 中截取的长度与原始 User-Agent 相同的子串,长度不足时会在末尾补空格。
|
2023-09-20 20:28:00 +08:00
|
|
|
|
|
2023-12-25 23:35:17 +08:00
|
|
|
|
## 在非 OpenWRT 系统上运行
|
|
|
|
|
|
|
|
|
|
自 `v4.5.0 起`,UA2F 支持在非 OpenWRT 系统上运行,但是需要手动配置防火墙规则,将需要处理的流量转发到 `netfilter-queue` 的 10010 队列中。
|
|
|
|
|
|
|
|
|
|
编译时,需要添加 `-DUA2F_ENABLE_UCI=OFF` flag 至 CMake。
|
|
|
|
|
|
2023-09-20 20:28:00 +08:00
|
|
|
|
## TODO
|
|
|
|
|
|
|
|
|
|
- [ ] pthread 支持,由不同线程完成入队出队
|
2024-03-16 23:36:45 +08:00
|
|
|
|
- [ ] 重写正则匹配为 parser
|
|
|
|
|
- [ ] 以连接为单位维护 parser 状态
|
2023-09-20 20:28:00 +08:00
|
|
|
|
|
|
|
|
|
## License
|
2024-03-16 23:36:45 +08:00
|
|
|
|
|
|
|
|
|
[GPL-3.0](./LICENSE)
|