# AIClient2API
**Repository Path**: justlovemaki/AIClient2API
## Basic Information
- **Project Name**: AIClient2API
- **Description**: Simulates Gemini CLI, Antigravity, Codex, Grok, and Kiro client requests, compatible with the OpenAI API. It supports thousands of Gemini model requests per day and offers free use of the built-in Cla
- **Primary Language**: Unknown
- **License**: GPL-3.0
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2026-05-20
- **Last Updated**: 2026-06-04
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README

# AIClient2API(A2)🚀
**一个能将多种仅客户端内使用的大模型 API(Gemini CLI, Antigravity, Codex, Grok, Kiro ...),模拟请求,统一封装为本地 OpenAI 兼容接口的强大代理。**
| 镜像下载量超100k |
trendshift.io上过榜2 |
|
|
[](https://deepwiki.com/justlovemaki/AIClient-2-API)
[](https://www.gnu.org/licenses/gpl-3.0)
[](https://nodejs.org/)
[](https://hub.docker.com/r/justlikemaki/aiclient-2-api)
[](https://github.com/justlovemaki/AIClient-2-API/stargazers)
[](https://github.com/justlovemaki/AIClient-2-API/issues)
[**🔧 OpenClaw 配置**](./docs/OPENCLAW_CONFIG_GUIDE-ZH.md) | [**👉 中文**](./README-ZH.md) | [English](./README.md) | [日本語](./README-JA.md) | [**📚 完整文档**](https://aiproxy.justlikemaki.vip/zh/)
---
## 💎 赞助商
*排序按赞助先后顺序排列,均推荐注册使用。*
|
PackyCode 是一家可靠且高效的 API 中转服务商,提供 Claude Code、Codex、Gemini 等模型的中转服务。PackyCode 为本软件用户提供特别优惠:通过此链接注册并在充值时输入 AIClient2API 优惠码,即可享受 10% 的折扣。
|
|
感谢 APIKEY.FUN 赞助本项目!APIKEY.FUN 是一家专业的企业级 AI 中转站,致力于为企业和个人开发者提供稳定、高效、低成本的其他 AI 模型 API 接入服务。平台支持 Claude、OpenAI、Gemini 等主流热门模型,价格低至官方原价的 7%。通过本项目专属链接注册,还可享受最高 充值永久 95 折 专属优惠。
|
|
感谢 VisionCoder 对本项目的支持。VisionCoder 开发平台 是一个可靠高效的 API 中继服务提供商,提供 Claude Code、Codex、Gemini 等主流 AI 模型,帮助开发者和团队更轻松地集成 AI 功能,提升工作效率。VisionCoder 还为我们的用户提供 Token Plan 限时活动:购买 1 个月,赠送 1 个月。
|
|
感谢 Atlas Cloud 赞助本项目!Atlas Cloud 是一款全模态 AI 推理平台,为开发者提供单一的 AI API 以轻松接入视频生成、图像生成和大语言模型 API。无需管理多个供应商集成,您只需连接一次,即可统一访问跨所有模态的 300 多种精选模型。欢迎查看 Atlas Cloud 全新的 编码计划促销活动 (coding plan),以获取更具性价比的 API 接入服务。
|
|
成为赞助商
如果您有意赞助本项目,请扫描左侧微信二维码(添加时请注明来意:赞助)。
|
---
## 🚀 项目概览
`AIClient2API` 是一个突破客户端限制的 API 代理服务,将 Gemini、Antigravity、Codex, Grok、Kiro 等原本仅限客户端内使用的免费大模型,转换为可供任何应用调用的标准 OpenAI 兼容接口。基于 Node.js 构建,支持 OpenAI、Claude、Gemini 三大协议的智能互转,让 Cherry-Studio、NextChat、Cline 等工具能够免费大量使用 Claude Opus、Gemini Pro 等高级模型。项目采用策略模式和适配器模式的模块化架构,内置账号池管理、智能轮询、自动故障转移和健康检查机制,确保 99.9% 的服务可用性。
> [!NOTE]
> **🎉 重要里程碑**
>
> - 感谢阮一峰老师在 [周刊 359 期](https://www.ruanyifeng.com/blog/2025/08/weekly-issue-359.html) 的推荐
>
> **📅 版本更新日志**
>
>
> 点击展开查看详细版本历史
>
> - **2026.06.03** - 新增 Grok Build(Grok CLI)支持:接入 `grok-cli-oauth` 的 xAI OAuth / Responses API 调用链,支持 Grok Build 文本模型、多协议转换、内置工具(网页搜索、X 搜索、代码解释器、集合/附件搜索)以及图片/视频生成模型。
> - **2026.05.04 (v3.0.0)** - **里程碑更新:AI 深度集成与自发现架构**。新增自动化 Skill 指南与远程 `/api/help`、`/api/example` 接口,支持 AI 代理无缝理解并操作 50+ 个全量 API 端点;实现了 CLI 与 REST API 输出结果的完全统一,增强了结构化 JSON 支持。
> - **2026.04.29** - 全面支持 OpenAI 标准的图片生成 (`/v1/images/generations`) 与编辑 (`/v1/images/edits`) 接口。支持自动将 OpenAI 格式请求转换为各模型对应的原生生图协议,并适配号池轮询与自动重试机制,大幅提升多模态创作的稳定性。
> - **2026.03.02** - 新增 Grok 协议支持,支持通过 Cookie/SSO 方式访问 xAI Grok 系列模型(Grok),支持多模态输入、图片/视频生成、自动 token 刷新及流式输出
> - **2026.01.26** - 新增 Codex 协议支持:支持 OpenAI Codex OAuth 授权接入
> - **2026.01.25** - 增强 AI 监控插件:支持监控 AI 协议转换前后的请求参数和响应。优化日志管理:统一日志格式,可视化配置
> - **2026.01.15** - 优化提供商池管理器:新增异步刷新队列机制、缓冲队列去重、全局并发控制,支持节点预热和自动过期检测
> > - **2026.01.03** - 新增主题切换功能并优化提供商池初始化,移除使用提供商默认配置的降级策略
> - **2025.12.30** - 添加主进程管理和自动更新功能
> - **2025.12.25** - 配置文件统一管理:所有配置集中到 `configs/` 目录,Docker 用户需更新挂载路径为 `-v "本地路径:/app/configs"`
> - **2025.12.11** - Docker 镜像自动构建并发布到 Docker Hub: [justlikemaki/aiclient-2-api](https://hub.docker.com/r/justlikemaki/aiclient-2-api)
> - **2025.11.30** - 新增 Antigravity 协议支持,支持通过 Google 内部接口访问 Gemini Pro、Claude Sonnet 等模型
> - **2025.11.11** - 新增 Web UI 管理控制台,支持实时配置管理和健康状态监控
> - **2025.11.06** - 新增对 Gemini 预览版的支持,增强模型兼容性和性能优化
> - **2025.10.18** - Kiro 开放注册,新用户赠送 500 额度,已完整支持 Claude Sonnet
> - **2025.08.29** - 发布账号池管理功能,支持多账号轮询、智能故障转移和自动降级策略
> - 配置方式:在 `configs/config.json` 中添加 `PROVIDER_POOLS_FILE_PATH` 参数
> - 参考配置:[provider_pools.json](./configs/provider_pools.json.example)
> - **历史已开发**
> - 支持 Gemini CLI、Kiro 等客户端2API
> - OpenAI ,Claude ,Gemini 三协议互转,自动智能切换
>
---
## 💡 核心优势
### 🤖 AI 优先,Agent 交互支持
> **AI 优先设计**:本项目原生支持与 OpenClaw, Hermes, Claude Code 等主流 AI Agent 的高效交互。
>
> **💡 快速指令**:你可以直接对 AI 说下面这句话,它将自动掌握本项目的所有用法:
>
> - **远程部署**:
> ```text
> 请加载并学习 https://raw.githubusercontent.com/justlovemaki/AIClient2API/main/docs/skills/aiclient-cli-usage.md 中的 Skill(服务地址为你的实际域名或 IP,登录密码为你的实际密码),以掌握 AIClient2API 的所有用法。
> ```
> - **本地模式**:
> 如果你在本地环境直接运行 AI 代理,可以直接发送:
> ```text
> 请加载并学习本项目的 docs/skills/aiclient-cli-usage.md 这一 Skill,以协助我本地启动、配置并管理 AIClient2API 服务。
> ```
### 🎯 统一接入,一站式管理
* **多模型统一接口**:通过标准 OpenAI 兼容协议,一次配置即可接入 Gemini、Claude、Grok、Codex、Kimi、MiniMax 等主流大模型
* **灵活切换机制**:Path 路由、支持通过启动参数、环境变量三种方式动态切换模型,满足不同场景需求
* **零成本迁移**:完全兼容 OpenAI API 规范,Cherry-Studio、NextChat、Cline 等工具无需修改即可使用
* **多协议智能转换**:支持 OpenAI、Claude、Gemini 三大协议间的智能转换,实现跨协议模型调用
### 🚀 突破限制,提升效率
* **绕过官方限制**:利用 OAuth 授权机制,有效突破 Gemini, Antigravity 等服务的免费 API 速率和配额限制
* **TLS 指纹绕过**:内置 TLS Sidecar (Go uTLS) 模拟浏览器特征,有效绕过 Grok 等服务的 Cloudflare 403 封锁
* **免费高级模型**:通过 Kiro API 模式免费使用 Claude Opus,降低使用成本
* **账号池智能调度**:支持多账号轮询、自动故障转移和配置降级,确保 99.9% 服务可用性
### 🛡️ 安全可控,数据透明
* **全链路日志记录**:捕获所有请求和响应数据,支持审计、调试
* **私有数据集构建**:基于日志数据快速构建专属训练数据集
* **系统提示词管理**:支持覆盖和追加两种模式,实现统一基础指令与个性化扩展的完美结合
### 🔧 开发友好,易于扩展
* **Web UI 管理控制台**:实时配置管理、健康状态监控、API 测试和日志查看
* **模块化架构**:基于策略模式和适配器模式,新增模型提供商仅需 3 步
* **完整测试保障**:集成测试和单元测试覆盖率 90%+,确保代码质量
* **容器化部署**:提供 Docker 支持,一键部署,跨平台运行
---
## 📑 快速导航
- [💡 核心优势](#-核心优势)
- [🚀 快速启动](#-快速启动)
- [🐳 Docker 部署](https://hub.docker.com/r/justlikemaki/aiclient-2-api)
- [📋 核心功能](#-核心功能)
- [🔐 授权配置指南](#-授权配置指南)
- [📁 授权文件存储路径](#-授权文件存储路径)
- [⚙️ 高级配置](#高级配置)
- [❓ 常见问题](#-常见问题)
- [📄 开源许可](#-开源许可)
- [🙏 致谢](#-致谢)
- [⚠️ 免责声明](#️-免责声明)
---
## 🔧 使用说明
### 🚀 快速启动
使用 AIClient2API 最推荐的方式是通过自动化脚本启动,并直接在 **Web UI 控制台** 进行可视化配置。
#### 🐳 Docker 快捷启动 (推荐)
```bash
docker run -d -p 3000:3000 -p 8085-8086:8085-8086 -p 1455:1455 -p 56121:56121 -p 19876-19880:19876-19880 --restart=always -v "指定路径/configs:/app/configs" -v "指定路径/plugins:/app/src/plugins-user" --name aiclient2api justlikemaki/aiclient-2-api
```
**参数说明**:
- `-d`:后台运行容器
- `-p 3000:3000 ...`:端口映射。3000 为 Web UI,其余为 OAuth 回调端口(Gemini: 8085, Antigravity: 8086, Codex: 1455, Grok CLI: 56121, Kiro: 19876-19880)
- `--restart=always`:容器自动重启策略
- `-v "指定路径/configs:/app/configs"`:挂载配置目录(请将"指定路径"替换为实际路径,如 `/home/user/aiclient2api`)
- `-v "指定路径/plugins:/app/src/plugins-user"`:挂载用户插件目录
- `--name aiclient2api`:容器名称
#### 🐳 Docker Compose 部署
你也可以使用 Docker Compose 进行部署。首先,进入 `docker` 目录:
```bash
cd docker
mkdir -p configs
docker compose up -d
```
如需从源码构建而非使用预构建镜像,请编辑 `docker-compose.yml`:
1. 注释掉 `image: justlikemaki/aiclient-2-api:latest` 行
2. 取消 `build:` 部分的注释
3. 运行 `docker compose up -d --build`
#### 1. 运行启动脚本
* **Linux/macOS**: `chmod +x install-and-run.sh && ./install-and-run.sh`
* **Windows**: 双击运行 `install-and-run.bat`
> **💡 如果脚本运行失败,可以尝试手动安装依赖并启动:**
> ```bash
> npm install
> # 默认启动
> npm start
> # 查看帮助信息
> npm run help
> # 查看 API 调用示例
> npm run example:api
> # 纯后端模式(禁用前端管理界面)
> npm start -- --no-ui
> ```
#### 2. 访问控制台
服务器启动后,打开浏览器访问:
👉 [**http://localhost:3000**](http://localhost:3000)
> **默认密码**: `admin123` (登录后可在控制台或修改 `pwd` 文件变更)
#### 3. 可视化配置 (推荐)
进入 **"配置管理"** 页面,您可以直接:
* ✅ 填入各提供商的 API Key 或上传 OAuth 凭据文件
* ✅ 实时切换默认模型提供商
* ✅ 监控健康状态和实时请求日志
#### 4. 本地环境准备 (非 Docker 用户)
如果您是在本地直接运行(通过脚本或 Node.js),且需要绕过 Grok 等服务的 TLS 检测,请务必:
* ✅ **安装 Go 语言环境**:前往 [Go 官网](https://go.dev/) 下载并安装 (1.20+)。
* ✅ **手动编译 Sidecar**:执行以下命令编译 TLS 代理组件:
```bash
cd tls-sidecar && go build -o tls-sidecar && cd ..
```
*注意:若未编译此二进制文件,TLS Sidecar 功能将因找不到执行文件而无法启动。*
#### 脚本执行示例
```
========================================
AI Client 2 API 快速安装启动脚本
========================================
[检查] 正在检查Node.js是否已安装...
✅ Node.js已安装,版本: v20.10.0
✅ 找到package.json文件
✅ node_modules目录已存在
✅ 项目文件检查完成
========================================
启动AI Client 2 API服务器...
========================================
🌐 服务器将在 http://localhost:3000 启动
📖 访问 http://localhost:3000 查看管理界面
⏹️ 按 Ctrl+C 停止服务器
```
> **💡 提示**:脚本会自动安装依赖并启动服务器。如果遇到任何问题,脚本会提供清晰的错误信息和解决建议。
---
### 📋 核心功能
#### Web UI 管理控制台

功能完善的 Web 管理界面,包含:
**📊 仪表盘**:系统概览、交互式路由示例、客户端配置指南
**⚙️ 配置管理**:实时参数修改,支持所有提供商(Gemini、Antigravity、OpenAI、Claude、Kiro),包含高级设置和文件上传
**🔗 提供商池**:监控活动连接、提供商健康统计、启用/禁用管理
**📁 配置文件**:OAuth 凭据集中管理,支持搜索过滤和文件操作
**📜 实时日志**:系统日志和请求日志实时显示,带管理控制
**🔐 登录验证**:默认密码 `admin123`,可通过 `pwd` 文件修改
访问:`http://localhost:3000` → 登录 → 侧边栏导航 → 立即生效
#### 多模态输入能力
支持图片、文档等多种类型的输入,为您提供更丰富的交互体验和更强大的应用场景。
#### 最新模型支持
无缝支持以下最新大模型,仅需在 Web UI 或 [`configs/config.json`](./configs/config.json) 中配置相应的端点:
* **Grok / Grok Build** - xAI 旗舰模型,现已通过 Grok Cookie/SSO 与 Grok CLI OAuth 支持,支持思考模型、Grok Build、内置工具、图片生成及视频生成
* **Claude Opus** - Anthropic 史上最强模型,现已通过 Kiro, Antigravity 支持
* **Gemini Pro** - Google 下一代架构预览版,现已通过 Gemini, Antigravity 支持
* **Kimi / MiniMax** - 国内顶级旗舰模型同步支持,现已通过自定义OpenAI,Claude 支持
---
### 🔐 授权配置指南
点击展开查看各提供商授权配置详细步骤
> **💡 提示**:为了获得最佳体验,建议通过 **Web UI 控制台** 进行可视化授权管理。
#### 🌐 Web UI 快捷授权 (推荐)
在 Web UI 管理界面中,您可以极速完成授权配置:
1. **生成授权**:在 **“提供商池”** 页面或**“配置管理”** 页面,点击对应提供商(如 Gemini)右上角的 **“生成授权”** 按钮。
2. **扫码/登录**:系统将弹出授权对话框,您可以点击 **“在浏览器中打开”** 进行登录验证。对于 Gemini,Antigravity 需完成 Google 账号授权。
3. **自动保存**:授权成功后,系统会自动获取凭据并保存至 `configs/` 对应目录下,您可以在 **“配置文件”** 页面看到新生成的凭据。
4. **可视化管理**:您可以随时在 Web UI 中上传、删除凭据,或通过 **“快速关联”** 功能将已有的凭据文件一键绑定到提供商。
#### Gemini CLI OAuth 配置
1. **获取OAuth凭据**:访问 [Google Cloud Console](https://console.cloud.google.com/) 创建项目,启用Gemini API
2. **项目配置**:可能需要提供有效的Google Cloud项目ID,可通过启动参数 `--project-id` 指定
3. **确保项目ID**:在 Web UI 中配置时,确保输入的项目ID与 Google Cloud Console 和 Gemini CLI 中显示的项目ID一致。
#### Antigravity OAuth 配置
1. **个人账号**:个人账号需要单独授权,已关闭申请渠道。
2. **Pro会员**:Antigravity 暂时对 Pro 会员开放,需要先购买 Pro 会员。
3. **组织账号**:组织账号需要单独授权,联系管理员获取授权。
#### Kiro API 配置
1. **环境准备**:[下载并安装 Kiro 客户端](https://kiro.dev/pricing/)
2. **完成授权**:在客户端中登录账号,生成 `kiro-auth-token.json` 凭据文件
3. **最佳实践**:推荐配合 **Claude Code** 使用,可获得最优体验
4. **重要提示**:Kiro 服务使用政策已更新,请访问官方网站查看最新使用限制和条款
#### Kiro 扩展思考 (Claude 模型)
AIClient2API 在使用路由到 `claude-kiro-oauth` 的 Claude 兼容请求 (`/v1/messages`) 或 OpenAI 兼容请求 (`/v1/chat/completions`) 时支持 Kiro 扩展思考。
**Claude 兼容接口 (`/v1/messages`)**:
```bash
curl http://localhost:3000/claude-kiro-oauth/v1/messages \
-H "Content-Type: application/json" \
-H "Authorization: Bearer your-api-key" \
-d '{
"model": "claude-sonnet-4-5",
"max_tokens": 1024,
"thinking": { "type": "enabled", "budget_tokens": 10000 },
"messages": [{ "role": "user", "content": "逐步解决这个问题。" }]
}'
```
**OpenAI 兼容接口 (`/v1/chat/completions`)**:
```bash
curl http://localhost:3000/claude-kiro-oauth/v1/chat/completions \
-H "Content-Type: application/json" \
-H "Authorization: Bearer your-api-key" \
-d '{
"model": "claude-sonnet-4-5",
"messages": [{ "role": "user", "content": "逐步解决这个问题。" }],
"extra_body": {
"anthropic": {
"thinking": { "type": "enabled", "budget_tokens": 10000 }
}
}
}'
```
**自适应模式**:
- Claude: `"thinking": { "type": "adaptive", "effort": "high" }`
- OpenAI: `"extra_body.anthropic.thinking": { "type": "adaptive", "effort": "high" }`
注意:
- `budget_tokens` 被限制在 `[1024, 24576]` 之间(如果省略或无效,默认值为 `20000`)。
- Token 获取/刷新/池轮换机制保持不变。
#### Codex OAuth 配置
1. **生成授权**:在 Web UI 的"提供商池"或"配置管理"页面,点击 Codex 的"生成授权"按钮
2. **浏览器登录**:系统将打开 OpenAI Codex 授权页面,完成 OAuth 登录
3. **自动保存**:授权成功后,系统会自动保存 Codex 的 OAuth 凭据文件
4. **回调端口**:确保 OAuth 回调端口 `1455` 未被占用
#### Grok CLI OAuth 配置
1. **生成授权**:在 Web UI 的“提供商池”或“配置管理”页面,点击 Grok CLI 的“生成授权”按钮
2. **浏览器登录**:系统将打开 xAI 授权页面,完成 OAuth 登录
3. **自动保存**:授权成功后,系统会自动保存 Grok CLI OAuth 凭据文件到 `configs/grok-cli/`
4. **回调端口**:确保 OAuth 回调端口 `56121` 未被占用
#### Grok Cookie/SSO 配置
1. **获取 SSO 令牌**:登录 [Grok 官网](https://grok.com/),在浏览器开发者工具的 Application -> Cookies 中复制 `sso` 的值
2. **填入配置**:在 Web UI 的“配置管理”或直接修改配置文件,将令牌填入 `GROK_COOKIE_TOKEN`
3. **支持功能**:
- 聊天与思考模型(Grok Thinking)
- 图片生成(Grok Imagine)
- 视频生成(Grok Video)
4. **注意事项**:确保 `GROK_USER_AGENT` 与您获取 Cookie 时使用的浏览器一致以避免被拦截
#### 账号池管理配置
1. **创建号池配置文件**:参考 [provider_pools.json.example](./configs/provider_pools.json.example) 创建配置文件
2. **配置号池参数**:在 `configs/config.json` 中设置 `PROVIDER_POOLS_FILE_PATH` 指向号池配置文件
3. **启动参数配置**:使用 `--provider-pools-file ` 参数指定号池配置文件路径
4. **健康检查**:系统会定期自动执行健康检查,不使用不健康的提供商
### 📁 授权文件存储路径
点击展开查看各服务授权凭据的默认存储位置
各服务的授权凭据文件默认存储位置:
| 服务 | 默认路径 | 说明 |
|------|---------|------|
| **Gemini** | `~/.gemini/oauth_creds.json` | OAuth 认证凭据 |
| **Kiro** | `~/.aws/sso/cache/kiro-auth-token.json` | Kiro 认证令牌 |
| **Antigravity** | `~/.antigravity/oauth_creds.json` | Antigravity OAuth 凭据 (支持 Claude Opus) |
| **Codex** | `~/.codex/oauth_creds.json` | Codex OAuth 凭据 |
| **Grok CLI** | `configs/grok-cli/..._xai-..._oauth_creds.json` | Grok CLI OAuth 凭据 |
> **说明**:`~` 表示用户主目录(Windows: `C:\Users\用户名`,Linux/macOS: `/home/用户名` 或 `/Users/用户名`)
> **自定义路径**:可通过配置文件中的相关参数或环境变量指定自定义存储位置
---
### 高级配置
点击展开查看代理配置、模型过滤及 Fallback 等高级设置
#### 1. 代理配置
本项目支持灵活的代理配置,可以为不同的提供商配置统一代理或使用提供商自带的已代理端点。
**配置方式**:
1. **Web UI 配置**(推荐):便捷的配置管理
在 Web UI 的"配置管理"页面中,可以可视化配置所有代理选项:
- **统一代理**:在"代理设置"区域填入代理地址,勾选需要使用代理的提供商
- **提供商端点**:在各提供商配置区域,直接修改 Base URL 为已代理的端点
- **点击"保存配置"**:即可生效,无需重启服务
2. **统一代理配置**:配置全局代理,并指定哪些提供商使用该代理
- **Web UI 配置**:在"配置管理"页面的"代理设置"区域填入代理地址,勾选需要使用代理的提供商
- **配置文件**:在 `configs/config.json` 中配置
```json
{
"PROXY_URL": "http://127.0.0.1:7890",
"PROXY_ENABLED_PROVIDERS": [
"gemini-cli-oauth",
"gemini-antigravity",
"claude-kiro-oauth",
"grok-web"
]
}
```
3. **提供商自带代理端点**:某些提供商(如 OpenAI、Claude)支持配置已代理的 API 端点
- **Web UI 配置**:在"配置管理"页面的各提供商配置区域,修改对应的 Base URL
- **配置文件**:在 `configs/config.json` 中配置
```json
{
"OPENAI_BASE_URL": "https://your-proxy-endpoint.com/v1",
"CLAUDE_BASE_URL": "https://your-proxy-endpoint.com"
}
```
**代理类型支持**:
- **HTTP 代理**:`http://127.0.0.1:7890`
- **HTTPS 代理**:`https://127.0.0.1:7890`
- **SOCKS5 代理**:`socks5://127.0.0.1:1080`
**使用场景**:
- **网络受限环境**:在无法直接访问 Google、OpenAI 等服务的网络环境中使用
- **混合配置**:部分提供商使用统一代理,部分使用自带的已代理端点
- **灵活切换**:可以随时在 Web UI 中启用/禁用特定提供商的代理
**注意事项**:
- 代理配置优先级:统一代理配置 > 提供商自带端点 > 直接连接
- 确保代理服务稳定可用,否则可能影响服务质量
- SOCKS5 代理通常比 HTTP 代理性能更好
#### 2. 模型过滤配置
支持通过 `notSupportedModels` 配置排除不支持的模型,系统会自动跳过这些提供商。
**配置方式**:在 `configs/provider_pools.json` 中为提供商添加 `notSupportedModels` 字段:
```json
{
"gemini-cli-oauth": [
{
"uuid": "provider-1",
"notSupportedModels": ["gemini-3.0-pro", "gemini-3.5-flash"],
"checkHealth": true
}
]
}
```
**工作原理**:
- 当请求特定模型时,系统会自动过滤掉配置了该模型为不支持的提供商
- 只有支持该模型的提供商才会被选中处理请求
**使用场景**:
- 某些账号因配额或权限限制无法访问特定模型
- 需要为不同账号分配不同的模型访问权限
#### 3. 跨类型 Fallback 配置
当某一 Provider Type(如 `gemini-cli-oauth`)下的所有账号都因 429 配额耗尽或被标记为 unhealthy 时,系统能够自动 fallback 到另一个兼容的 Provider Type(如 `gemini-antigravity`),而不是直接返回错误。
**配置方式**:在 `configs/config.json` 中添加 `providerFallbackChain` 配置:
```json
{
"providerFallbackChain": {
"gemini-cli-oauth": ["gemini-antigravity"],
"gemini-antigravity": ["gemini-cli-oauth"],
"claude-kiro-oauth": ["claude-custom"],
"claude-custom": ["claude-kiro-oauth"]
}
}
```
**工作原理**:
1. 尝试从主 Provider Type 池选取 healthy 账号
2. 如果该类型所有账号都 unhealthy:
- 查找配置的 fallback 类型
- 检查 fallback 类型是否支持当前请求的模型(协议兼容性检查)
- 从 fallback 类型的池中选取 healthy 账号
3. 支持多级降级链:`gemini-cli-oauth → gemini-antigravity → openai-custom`
4. 如果所有 fallback 类型也不可用,才返回错误
**使用场景**:
- 批量任务场景下,单一 Provider Type 的免费 RPD 配额容易在短时间内耗尽
- 通过跨类型 Fallback,可以充分利用多种 Provider 的独立配额,提高整体可用性和吞吐量
**注意事项**:
- Fallback 只会在协议兼容的类型之间进行(如 `gemini-*` 之间、`claude-*` 之间)
- 系统会自动检查目标 Provider Type 是否支持当前请求的模型
#### 4. TLS Sidecar (Bypass 403/Cloudflare)
针对 Grok 等对 TLS 指纹(JA3/JA4)校验严格的服务,本项目集成了基于 Go uTLS 的 Sidecar 代理,通过模拟浏览器 TLS 特征有效解决 403 Forbidden 报错。
**配置说明**:
1. **编译二进制文件**:
由于 TLS 模拟需要 Go 语言支持,您需要先编译 sidecar:
```bash
cd tls-sidecar
go build -o tls-sidecar
```
*Windows 用户编译后请确保生成的 `tls-sidecar.exe` 位于 `tls-sidecar/` 或根目录。*
2. **启用配置**:
在 Web UI 的“配置管理”中开启 **TLS Sidecar**,或修改 `configs/config.json`:
```json
{
"TLS_SIDECAR_ENABLED": true,
"TLS_SIDECAR_PORT": 9090
}
```
3. **工作原理**:
- 开启后系统自动启动并管理该 Go 进程。
- 针对特定提供商(如 Grok)的请求会自动路由至 Sidecar。
- Sidecar 使用 Chrome 最新指纹进行 TLS 握手,支持 HTTP/2 自动协商。
**注意事项**:
- 本地运行需安装 Go 环境(1.20+)。
- **Docker 用户**:镜像已内置编译好的二进制,只需在配置中开启即可,无需手动编译。
---
## ❓ 常见问题
点击展开查看常见问题及解决方案(端口占用、Docker 启动、429 错误等)
### 1. OAuth 授权失败
**问题描述**:点击"生成授权"后,浏览器打开授权页面但授权失败或无法完成。
**解决方案**:
- **检查网络连接**:确保能够正常访问 Google、阿里云等服务
- **检查端口占用**:OAuth 回调需要特定端口(Gemini: 8085, Antigravity: 8086, Codex: 1455, Grok CLI: 56121, Kiro: 19876-19880),确保这些端口未被占用
- **清除浏览器缓存**:尝试使用无痕模式或清除浏览器缓存后重试
- **检查防火墙设置**:确保防火墙允许本地回调端口的访问
- **Docker 用户**:确保已正确映射所有 OAuth 回调端口
### 2. 端口被占用
**问题描述**:启动服务时提示端口已被占用(如 `EADDRINUSE`)。
**解决方案**:
```bash
# Windows - 查找占用端口的进程
netstat -ano | findstr :3000
# 然后使用任务管理器结束对应 PID 的进程
# Linux/macOS - 查找并结束占用端口的进程
lsof -i :3000
kill -9
```
或者修改 `configs/config.json` 中的端口配置使用其他端口。
### 3. Docker 容器无法启动
**问题描述**:Docker 容器启动失败或立即退出。
**解决方案**:
- **检查日志**:`docker logs aiclient2api` 查看错误信息
- **检查挂载路径**:确保 `-v` 参数中的本地路径存在且有读写权限
- **检查端口冲突**:确保所有映射的端口在宿主机上未被占用
- **重新拉取镜像**:`docker pull justlikemaki/aiclient-2-api:latest`
### 4. 凭据文件无法识别
**问题描述**:上传或配置凭据文件后,系统提示无法识别或格式错误。
**解决方案**:
- **检查文件格式**:确保凭据文件是有效的 JSON 格式
- **检查文件路径**:确保文件路径正确,Docker 用户需确保文件在挂载目录内
- **检查文件权限**:确保服务有权限读取凭据文件
- **重新生成凭据**:如果凭据已过期,尝试重新进行 OAuth 授权
### 5. 请求返回 429 错误
**问题描述**:API 请求频繁返回 429 Too Many Requests 错误。
**解决方案**:
- **配置账号池**:添加多个账号到 `provider_pools.json`,启用轮询机制
- **配置 Fallback**:在 `config.json` 中配置 `providerFallbackChain`,实现跨类型降级
- **启用 429 短冷却**:将 `RATE_LIMIT_COOLDOWN_ENABLED` 设为 `true`,并通过 `RATE_LIMIT_COOLDOWN_MS` 设置默认冷却时间,让被限流账号短暂退出账号池后自动恢复
- **降低请求频率**:适当增加请求间隔,避免触发速率限制
- **等待配额重置**:免费配额通常每日或每分钟重置
### 6. 模型不可用或返回错误
**问题描述**:请求特定模型时返回错误或提示模型不可用。
**解决方案**:
- **检查模型名称**:确保使用正确的模型名称(区分大小写)
- **检查提供商支持**:确认当前配置的提供商支持该模型
- **检查账号权限**:某些高级模型可能需要特定账号权限
- **配置模型过滤**:使用 `notSupportedModels` 排除不支持的模型
### 7. Web UI 无法访问
**问题描述**:浏览器无法打开 `http://localhost:3000`。
**解决方案**:
- **检查服务状态**:确认服务已成功启动,查看终端输出
- **检查端口映射**:Docker 用户确保 `-p 3000:3000` 参数正确
- **尝试其他地址**:尝试访问 `http://127.0.0.1:3000`
- **检查防火墙**:确保防火墙允许 3000 端口的访问
### 8. 流式响应中断
**问题描述**:使用流式输出时,响应中途中断或不完整。
**解决方案**:
- **检查网络稳定性**:确保网络连接稳定
- **增加超时时间**:在客户端配置中增加请求超时时间
- **检查代理设置**:如使用代理,确保代理支持长连接
- **查看服务日志**:检查是否有错误信息
### 9. 配置修改不生效
**问题描述**:在 Web UI 中修改配置后,服务行为未改变。
**解决方案**:
- **刷新页面**:修改后刷新 Web UI 页面
- **检查保存状态**:确认配置已成功保存(查看提示信息)
- **重启服务**:某些配置可能需要重启服务才能生效
- **检查配置文件**:直接查看 `configs/config.json` 确认修改已写入
### 10. 访问接口返回 404
**问题描述**:调用 API 接口时返回 404 Not Found 错误。
**解决方案**:
- **检查接口路径**:确保使用正确的接口路径,如 `/v1/chat/completions` 等
- **检查客户端自动补全**:某些客户端(如 Cherry-Studio、NextChat)会自动在 Base URL 后追加路径(如 `/v1/chat/completions`),导致路径重复。请查看控制台中的实际请求 URL,移除多余的路径部分
- **检查服务状态**:确认服务已正常启动,访问 `http://localhost:3000` 查看 Web UI
- **检查端口配置**:确保请求发送到正确的端口(默认 3000)
- **查看可用路由**:在 Web UI 仪表盘页面查看"交互式路由示例"了解所有可用接口
### 11. Unauthorized: API key is invalid or missing
**问题描述**:调用 API 接口时返回 `Unauthorized: API key is invalid or missing.` 错误。
**解决方案**:
- **检查 API Key 配置**:确保在 `configs/config.json` 或 Web UI 中正确配置API Key
- **检查请求头格式**:确保请求中包含正确格式的 Authorization 头,如 `Authorization: Bearer your-api-key`
- **查看服务日志**:在 Web UI 的"实时日志"页面查看详细错误信息,定位具体原因
### 12. No available and healthy providers for type
**问题描述**:调用 API 时返回 `No available and healthy providers for type xxx` 错误。
**解决方案**:
- **检查提供商状态**:在 Web UI 的"提供商池"页面查看对应类型的提供商是否处于健康状态
- **检查凭据有效性**:确认 OAuth 凭据未过期,如已过期需重新生成授权
- **检查配额限制**:某些提供商可能已达到免费配额上限,等待配额重置或添加更多账号
- **启用 Fallback**:在 `config.json` 中配置 `providerFallbackChain`,当主提供商不可用时自动切换到备用提供商
- **查看详细日志**:在 Web UI 的"实时日志"页面查看具体的健康检查失败原因
### 13. 请求返回 403 Forbidden 错误
**问题描述**:API 请求返回 403 Forbidden 错误。
**解决方案**:
- **开启 TLS Sidecar**:针对 Grok 等服务,403 通常是因为 TLS 指纹被屏蔽。请参考 [高级配置 - TLS Sidecar](#5-tls-sidecar-bypass-403cloudflare) 开启并编译 Sidecar。
- **检查节点状态**:如果在 Web UI 的"提供商池"页面中看到节点状态正常(健康检查通过),则可以忽略此报错,系统会自动处理
- **检查账号权限**:确认使用的账号有权限访问请求的模型或服务
- **检查 API Key 权限**:某些提供商的 API Key 可能有访问范围限制,确保 Key 有足够权限
- **检查地区限制**:部分服务可能有地区访问限制,尝试使用代理或 VPN
- **检查凭据状态**:OAuth 凭据可能已被撤销或失效,尝试重新生成授权
- **检查请求频率**:某些提供商对请求频率有严格限制,降低请求频率后重试
- **查看提供商文档**:访问对应提供商的官方文档,了解具体的访问限制和要求
### 14. 为什么要开启“启用OAuth令牌自动刷新”?
**问题描述**:不确定是否需要开启令牌自动刷新功能。
**解决方案**:
OAuth 令牌(如 Gemini, Antigravity, Codex)通常有一定的有效期(如 1 小时)。
- **开启后**:系统会在后台自动检查并刷新即将过期的令牌。这能确保提供 24/7 稳定的 API 服务,避免因令牌过期导致的 `401 Unauthorized` 或 `403 Forbidden` 错误。
- **不开启**:令牌过期后,系统无法自动获取新令牌,导致 API 请求失败,直到您手动重新进行 OAuth 授权。
### 15. “预加载模型提供商”未开启对 Token 保持有什么影响?
**问题描述**:不理解“预加载模型提供商”配置的作用及其对 Token 的影响。
**解决方案**:
系统仅会对**已加载到活跃池中**的提供商执行自动刷新任务。
- **影响**:如果您在配置中未勾选某个提供商作为“预加载模型提供商”,系统启动时不会初始化该提供商。即使开启了“自动刷新”,后台任务也**不会**去刷新这个未激活提供商的令牌。
- **后果**:如果您长时间不使用该提供商,其 Token 会在后台静默过期。当您偶尔通过特定路由调用它时,会因为 Token 过期而请求失败。
- **建议**:对于需要长期稳定使用的提供商,请务必在“预加载模型提供商”中进行勾选。
---
## 📄 开源许可
本项目遵循 [**GNU General Public License v3 (GPLv3)**](https://www.gnu.org/licenses/gpl-3.0) 开源许可。详情请查看根目录下的 `LICENSE` 文件。
## 🙏 致谢
本项目的开发受到了官方 Google Gemini CLI 的极大启发,并参考了Cline 3.18.0 版本 `gemini-cli.ts` 的部分代码实现。在此对 Google 官方团队和 Cline 开发团队的卓越工作表示衷心的感谢!
### 贡献者列表
感谢以下所有为 AIClient2API 项目做出贡献的开发者:
[](https://github.com/justlovemaki/AIClient-2-API/graphs/contributors)
### 🌟 Star History
[](https://www.star-history.com/#justlovemaki/AIClient-2-API&Timeline)
---
## ⚠️ 免责声明
### 使用风险提示
本项目(AIClient2API)仅供学习和研究使用。用户在使用本项目时,应自行承担所有风险。作者不对因使用本项目而导致的任何直接、间接或 consequential 损失承担责任。
### 第三方服务责任说明
本项目是一个API代理工具,不提供任何AI模型服务。所有AI模型服务由相应的第三方提供商(如Google、OpenAI、Anthropic等)提供。用户在使用本项目访问这些第三方服务时,应遵守各第三方服务的使用条款和政策。作者不对第三方服务的可用性、质量、安全性或合法性承担责任。
### 数据隐私说明
本项目在本地运行,不会收集或上传用户的任何数据。但用户在使用本项目时,应注意保护自己的API密钥和其他敏感信息。建议用户定期检查和更新自己的API密钥,并避免在不安全的网络环境中使用本项目。
### 法律合规提醒
用户在使用本项目时,应遵守所在国家/地区的法律法规。严禁将本项目用于任何非法用途。如因用户违反法律法规而导致的任何后果,由用户自行承担全部责任。