本文档详细说明如何将不同类型的 AI 中转站、官方兼容入口和 OAuth 连接接入 Metapi。
Metapi 当前支持三类上游接入方式:
- 中转聚合平台 — New API / One API / OneHub / DoneHub / Veloera / AnyRouter / Sub2API / CPA 等
- 官方 API 端点 — OpenAI / Claude (Anthropic) / Gemini (Google) 直连
- 官方预设与 OAuth 连接 — Coding Plan / DeepSeek / Moonshot / MiniMax / ModelScope 等官方兼容入口,以及 Codex / Claude / Gemini CLI / Antigravity 的浏览器授权登录
其中:
- 平台类型 决定协议适配和管理能力
- 官方预设 还是落在
openai/claude这类平台上,但会自动带出官方地址和推荐模型 - OAuth 连接 不在「站点管理」里手填账号密码,而是在「OAuth 管理」里单独授权
每种接入方式略有不同,本文档按类型分别说明。
- 登录管理后台 — 访问
http://your-metapi-host:4000,使用AUTH_TOKEN登录 - 进入站点管理 — 点击左侧菜单「站点管理」
- 添加站点 — 点击「添加站点」按钮
- 填写站点信息 — 根据站点类型填写对应字段;如果是官方入口,也可以直接选择预设
- 添加连接 — 按场景继续添加账号、API Key,或改去「OAuth 管理」授权
- 验证连接 — 系统自动验证账号可用性并获取模型列表
| 你手上有什么 | 推荐入口 | 推荐方式 |
|---|---|---|
| 有后台面板的聚合站 | 站点管理 | 先加站点,再加账号 / Session |
| 只有 Base URL + API Key 的兼容接口 | 站点管理 | 先加站点,再加 API Key |
| 官方 Coding / API 兼容入口 | 站点管理 | 直接选择官方预设 |
| Codex / Claude / Gemini CLI / Antigravity 的 provider 账号 | OAuth 管理 | 直接浏览器授权 |
适用平台: New API 及其衍生版本(AnyRouter、VO-API、Super-API、RIX-API、Neo-API 等)
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称,便于识别 | 我的 New API |
| 站点 URL | New API 部署地址(不含 /v1 后缀) |
https://api.example.com |
| 平台类型 | 选择 new-api |
- |
| 代理 URL | (可选)该站点专用代理地址 | http://proxy.example.com:7890 |
| 使用系统代理 | 是否使用全局 SYSTEM_PROXY_URL |
默认关闭 |
New API 支持三种凭证类型:
- 适用场景: 有完整账号权限,需要自动签到、余额查询、账号令牌管理
- 填写方式:
- 用户名:
your-username - 密码:
your-password
- 用户名:
- 自动获取: 系统自动登录并获取 Access Token 和账号令牌
- 适用场景: 已有登录凭证,无需密码
- 填写方式:
- 自动解析: 系统自动识别凭证类型并提取用户信息
- 适用场景: 仅用于模型调用,不需要余额管理、自动签到等功能
- 填写方式:
- 在「API Token」字段填入:
sk-xxxxxxxxxxxxxx
- 在「API Token」字段填入:
- 限制: 无法使用签到、余额刷新、账号令牌管理等功能
User ID 自动探测: New API 通常需要在请求头中携带 New-API-User / Veloera-User / voapi-user 等字段。Metapi 会自动:
- 从 JWT Token 中解码 User ID
- 从 Session Cookie 中提取 User ID(支持 Gob 编码解析)
- 通过探测常见 ID 范围验证可用性
如果以上方法都不能获取到 ID,则需要用户手动获取。
防护盾穿透: 自动处理阿里云盾 / Cloudflare 等 JS 挑战(acw_sc__v2 / cdn_sec_tc),无需手动配置。
适用平台: One API 原版及兼容分支
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | One API 主站 |
| 站点 URL | One API 部署地址 | https://oneapi.example.com |
| 平台类型 | 选择 one-api |
- |
One API 支持与 New API 相同的三种凭证类型(用户名密码 / Access Token / API Key),配置方式相同。
适用平台: OneHub(One API 增强分支)
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | OneHub 站点 |
| 站点 URL | OneHub 部署地址 | https://onehub.example.com |
| 平台类型 | 选择 one-hub |
- |
OneHub 继承 One API 的凭证体系,支持用户名密码、Access Token、API Key 三种方式。
额外功能: OneHub 支持 Token 分组(token_group),Metapi 会自动识别并保留分组信息。
适用平台: DoneHub(OneHub 增强分支)
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | DoneHub 站点 |
| 站点 URL | DoneHub 部署地址 | https://donehub.example.com |
| 平台类型 | 选择 done-hub |
- |
DoneHub 完全兼容 OneHub 的凭证体系,配置方式相同,DoneHub 获取令牌位置如下图所示:
适用平台: Veloera API 网关
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | Veloera 网关 |
| 站点 URL | Veloera 部署地址 | https://veloera.example.com |
| 平台类型 | 选择 veloera |
- |
Veloera 基于 New API 架构,支持相同的凭证类型。特别注意:
- Veloera 需要
Veloera-User请求头,Metapi 会自动添加
适用平台: Sub2API 订阅制中转平台
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | Sub2API 订阅站 |
| 站点 URL | Sub2API 部署地址 | https://sub2api.example.com |
| 平台类型 | 选择 sub2api |
- |
Sub2API 常见 JWT 短期会话机制,和传统 NewAPI 站点差异较大。按下面步骤进行添加:
首先去中转站点 F12 打开如下界面:
然后回到 Metapi 账号添加处:
- 在「凭证模式」里选择 Session 模式,分别粘贴 F12 界面中的
auth_token、refresh_token、token_expires_at字段进行验证,无需配置用户 ID。 - 不要使用账号密码登录,Metapi 不支持代替 Sub2API 做登录
- Sub2API 通常为订阅制使用,不支持签到;如果你只关心代理调用,也可以直接改用 API Key 模式
- 若
GET /v1/models为空,先确认该账号下已有可用用户 API Key,Metapi 会再尝试用它发现模型
适用平台: CLIProxyAPI / CPA 一类标准 API provider
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | 本地 CPA |
| 站点 URL | CPA 暴露的 Base URL | http://127.0.0.1:8317 |
| 平台类型 | 选择 cliproxyapi |
- |
CPA 这类站点推荐直接使用 API Key:
- 在「API Token」字段填入 CPA 提供的密钥
- 不建议把它当成可签到、可查余额、可账号登录的传统面板站
- 本地默认地址常见为
http://127.0.0.1:8317 - 远端实例也可能通过
cliproxy/cpa风格 URL 或响应头被自动识别 - 当前重点支持 模型发现 与 代理调用
- 不支持用户名密码登录、自动签到、站点余额 / 用户信息抓取
适用场景: 直连 OpenAI 官方 API 或 OpenAI 兼容端点
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | OpenAI 官方 |
| 站点 URL | OpenAI API 端点(不含 /v1 后缀) |
https://api.openai.com |
| 平台类型 | 选择 openai |
- |
| 代理 URL | (推荐)配置代理以访问 OpenAI | http://proxy.example.com:7890 |
仅支持 API Key:
- 在「API Token」字段填入:
sk-proj-xxxxxxxxxxxxxx - 不支持用户名密码登录(OpenAI 无此接口)
| 功能 | 支持情况 |
|---|---|
| 模型列表获取 | ✅ 支持(/v1/models) |
| 代理调用 | ✅ 支持 |
| 余额查询 | ❌ 不支持(OpenAI 无公开接口) |
| 自动签到 | ❌ 不适用 |
| 账号令牌管理 | ❌ 不适用 |
适用场景: 直连 Anthropic Claude API
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | Claude 官方 |
| 站点 URL | Anthropic API 端点 | https://api.anthropic.com |
| 平台类型 | 选择 claude |
- |
仅支持 API Key:
- 在「API Token」字段填入:
sk-ant-api03-xxxxxxxxxxxxxx
| 功能 | 支持情况 |
|---|---|
| 模型列表获取 | ✅ 支持(内置模型目录) |
| 代理调用 | ✅ 支持(自动转换 OpenAI ⇄ Claude 格式) |
| 余额查询 | ❌ 不支持 |
| 自动签到 | ❌ 不适用 |
| 账号令牌管理 | ❌ 不适用 |
协议转换: Metapi 自动处理 OpenAI 格式与 Claude Messages API 格式的双向转换,下游客户端可使用 OpenAI SDK 调用 Claude 模型。
适用场景: 直连 Google Gemini API
| 字段 | 说明 | 示例 |
|---|---|---|
| 站点名称 | 自定义名称 | Gemini 官方 |
| 站点 URL | Gemini API 端点 | https://generativelanguage.googleapis.com |
| 平台类型 | 选择 gemini |
- |
仅支持 API Key:
- 在「API Token」字段填入:
AIzaSyxxxxxxxxxxxxxx
| 功能 | 支持情况 |
|---|---|
| 模型列表获取 | ✅ 支持(/v1beta/models) |
| 代理调用 | ✅ 支持(自动转换 OpenAI ⇄ Gemini 格式) |
| 余额查询 | ❌ 不支持 |
| 自动签到 | ❌ 不适用 |
| 账号令牌管理 | ❌ 不适用 |
协议转换: Metapi 自动处理 OpenAI 格式与 Gemini generateContent API 格式的双向转换。
除了手动选择 openai / claude 平台,现在站点编辑器里还内置了一批官方预设。这类预设更适合:
- 直接接官方兼容入口
- 自动填入官方推荐 URL
- 先用 API Key 初始化,再补推荐模型
- 保留接入语义,后续创建完站点后更容易知道下一步怎么配
| 预设 | 底层平台 | 默认地址 | 推荐说明 |
|---|---|---|---|
| 阿里云 CodingPlan / OpenAI | openai |
https://coding.dashscope.aliyuncs.com/v1 |
推荐先加 API Key,再补编程模型 |
| 阿里云 CodingPlan / Claude | claude |
https://coding.dashscope.aliyuncs.com/apps/anthropic |
适合 Claude Code 一类工具直连 |
| 智谱 Coding Plan / OpenAI | openai |
https://open.bigmodel.cn/api/coding/paas/v4 |
推荐先加 API Key,再补 GLM 编程模型 |
| 智谱 Coding Plan / Claude | claude |
https://open.bigmodel.cn/api/anthropic |
当前更适合手动选择预设 |
| DeepSeek / OpenAI | openai |
https://api.deepseek.com/v1 |
适合直接接 DeepSeek 官方兼容入口 |
| DeepSeek / Claude | claude |
https://api.deepseek.com/anthropic |
适合 Claude 兼容用法 |
| Moonshot(Kimi) / OpenAI | openai |
https://api.moonshot.cn/v1 |
适合 Kimi 官方 OpenAI 兼容入口 |
| Moonshot(Kimi) / Claude | claude |
https://api.moonshot.cn/anthropic |
适合 Claude 兼容用法 |
| MiniMax / OpenAI | openai |
https://api.minimaxi.com/v1 |
推荐先加 API Key |
| MiniMax / Claude | claude |
https://api.minimaxi.com/anthropic |
适合 Claude Code 兼容入口 |
| ModelScope / OpenAI | openai |
https://api-inference.modelscope.cn/v1 |
适合开源编程模型兼容接入 |
| ModelScope / Claude | claude |
https://api-inference.modelscope.cn |
适合 Claude 兼容接入 |
| 豆包 Coding Plan / OpenAI | openai |
https://ark.cn-beijing.volces.com/api/coding/v3 |
适合火山方舟 Coding Plan |
- 选中预设后,优先保留它自动填好的 URL
- 如果你只是接一个普通自建网关,不想保留预设语义,再手动改回通用
openai/claude - 对官方预设来说,不要机械地把
/v1或/anthropic删掉,以预设默认值为准
有些 provider 更适合在左侧菜单 OAuth 管理 里直接授权,而不是在「站点管理 → 账号管理」里手填凭证。
| Provider | 对应平台 | 自动创建的站点名 | 适用说明 |
|---|---|---|---|
| Codex | codex |
ChatGPT Codex OAuth |
直接授权 Codex 账号 |
| Claude | claude |
Anthropic Claude OAuth |
直接授权 Claude / Anthropic 账号 |
| Gemini CLI | gemini-cli |
Google Gemini CLI OAuth |
支持浏览器授权,可选 Project ID |
| Antigravity | antigravity |
Google Antigravity OAuth |
适合 Antigravity provider 登录 |
- 你接的不是一个普通面板站,而是 provider 自己的账号
- 你不想手填 Cookie / Session / API Key
- 你希望后续刷新、重绑也继续走 provider 官方授权流程
- 进入左侧菜单 OAuth 管理
- 选择对应 provider 发起授权
- 如果是远程部署,按页面提示使用 SSH 隧道或手动回填 callback URL
- 授权成功后,Metapi 会自动创建或复用对应站点与连接
完整流程见 OAuth 管理。
每个站点可单独配置代理,优先级高于全局 SYSTEM_PROXY_URL:
站点专用代理 > 全局系统代理 > 直连
配置方式:
- 在站点编辑页面填写「代理 URL」字段
- 格式:
http://proxy-host:port或socks5://proxy-host:port - 支持 HTTP / HTTPS / SOCKS5 代理
全局权重(global_weight): 影响该站点下所有通道的路由概率。
- 默认值:
1.0 - 范围:
0.1~10.0 - 示例:
- 设置为
2.0— 该站点通道被选中的概率翻倍 - 设置为
0.5— 该站点通道被选中的概率减半
- 设置为
配置位置: 站点编辑页面 → 高级设置 → 全局权重
适用场景: 某些站点的签到接口非标准路径,或需要通过外部服务触发签到。
配置方式:
- 在站点编辑页面填写「外部签到 URL」
- Metapi 会向该 URL 发送 POST 请求执行签到
- 请求头自动携带账号凭证
现在不少站点已经不是“一个 URL 同时负责后台面板和 /v1/* API 请求”。
Metapi 当前支持把这两层拆开:
- 主站点 URL:用于登录、签到、后台接口、系统访问令牌管理
- API 请求地址池:用于真正转发
/v1/*、/chat/completions、/responses等模型请求
适合填写 API 请求地址池的场景:
- 控制台地址和 API 网关地址不同
- 同一个站点有多个 API host,需要健康切换
- 你想保留面板地址不变,只把模型流量导向专用网关
简单理解:
主站点 URL = 控制面
API 请求地址池 = 数据面
Metapi 支持自动识别站点类型,当前检测优先级如下:
下列地址会优先识别成官方预设,并返回 initializationPresetId:
| URL / 特征 | 识别结果 |
|---|---|
coding.dashscope.aliyuncs.com/v1 |
codingplan-openai |
coding.dashscope.aliyuncs.com/apps/anthropic |
codingplan-claude |
open.bigmodel.cn/api/coding/paas/v4 |
zhipu-coding-plan-openai |
api.deepseek.com/v1 |
deepseek-openai |
api.deepseek.com/anthropic |
deepseek-claude |
api.moonshot.cn/v1 |
moonshot-openai |
api.moonshot.cn/anthropic |
moonshot-claude |
api.minimaxi.com/v1 |
minimax-openai |
api.minimaxi.com/anthropic |
minimax-claude |
api-inference.modelscope.cn/v1 |
modelscope-openai |
api-inference.modelscope.cn |
modelscope-claude |
ark.cn-beijing.volces.com/api/coding/v3 |
doubao-coding-openai |
Note
智谱 Coding Plan 的 Claude 兼容入口当前不会按 URL 强制自动识别,更适合手动选预设。
根据 URL 中的关键字自动识别:
| URL 特征 | 识别为 |
|---|---|
api.openai.com |
OpenAI |
api.anthropic.com |
Claude |
generativelanguage.googleapis.com |
Gemini |
chatgpt.com/backend-api/codex |
Codex |
127.0.0.1:8317 / localhost:8317 / cliproxy |
CLIProxyAPI / CPA |
anyrouter |
AnyRouter |
donehub / done-hub |
DoneHub |
onehub / one-hub |
OneHub |
veloera |
Veloera |
sub2api |
Sub2API |
访问站点首页,解析 <title> 标签识别平台类型。
依次尝试各平台的特征接口:
- New API:
/api/status返回system_name - One API:
/api/status返回特定结构 - OpenAI:
/v1/models返回模型列表 - CPA:
/v0/management/openai-compatibility返回兼容信息或特征响应头
手动指定: 如果自动检测失败,可在添加站点时手动选择平台类型或直接选择官方预设。
Metapi 自动追踪每个账号的健康状态:
| 状态 | 说明 | 触发条件 |
|---|---|---|
healthy |
健康 | 最近请求成功,余额充足 |
degraded |
降级 | 部分模型不可用,或余额不足 |
unhealthy |
不健康 | 连续失败,或凭证过期 |
disabled |
已禁用 | 手动禁用或站点禁用 |
自动恢复: unhealthy 状态的账号会定期重试,成功后自动恢复为 healthy。
Metapi 会定期抓取已接入站点的公告,并在首次发现时写入站内通知与「站点公告」页面。
当前支持的公告来源:
new-api:读取/api/notice的全站公告done-hub:读取/api/notice的全站公告sub2api:读取/api/v1/announcements的公告列表
行为约定:
- 首次发现的公告会触发一次 Metapi 通知
- 已经保存过的公告再次同步时只更新本地记录
sub2api这类需要登录态的公告接口,会优先使用站点下已启用账号的会话令牌- 「站点公告」页面的清空操作只影响 Metapi 本地数据库
可能原因:
- 站点 URL 填写错误
- 通用平台常见是填根地址,错误地带上了不该带的
/v1 - 官方预设则相反,不要把预设自动带出的
/v1//anthropic//api/coding/...手动删掉
- 通用平台常见是填根地址,错误地带上了不该带的
- 网络不通(检查代理配置或防火墙)
- 凭证无效(重新验证账号密码、Session 或 API Key)
- 主站点 URL 和真实 API 请求地址不同,但还没配置 API 请求地址池
解决方法:
- 在站点详情页点击「测试连接」
- 查看「事件日志」中的错误信息
- 检查「代理日志」中的请求详情
原因: 该站点是 New API 衍生版本,需要 User ID。
解决方法:
-
Metapi 会自动探测 User ID,通常无需手动配置
-
如果自动探测失败,可在账号编辑页面的「额外配置」中手动填写:
{ "platformUserId": 12345 }
原因: cliproxyapi / CPA 在 Metapi 里按标准 API provider 处理,重点支持模型发现与代理调用,不按传统面板站处理。
解决方法:
- 直接使用 API Key 模式
- 不要再按「用户名密码登录 + 自动签到」的思路排查
原因: 你接的不是普通面板站,而是 provider 自己的授权账号。
解决方法:
- Codex / Claude / Gemini CLI / Antigravity 这类连接直接去左侧 OAuth 管理
- 不要在账号管理里反复尝试 Cookie / Session / API Key 兜底
可能原因:
- 凭证过期(Access Token 有效期到期)
- 站点签到接口变更
- 已经签到过(部分站点限制每日一次)
解决方法:
- 查看「签到记录」中的失败原因
- 尝试重新登录获取新凭证
- 配置「外部签到 URL」使用备用签到方式
原因: 不同平台的余额单位不同。
说明:
- New API 系列:余额单位为「美元」,内部存储为
quota / 500000 - OpenAI / Claude / Gemini / CPA:官方或兼容 API 通常无余额查询接口,显示为
N/A
| 场景 | 推荐凭证类型 | 原因 |
|---|---|---|
| 个人站点,需要完整功能 | 用户名密码 / Access Token | 支持自动签到、账号令牌管理 |
| 共享账号,只读权限 | Access Token | 避免密码泄露 |
| 仅用于模型调用 | API Token | 最小权限原则 |
| Provider 原生账号 | OAuth | 更适合后续刷新、重绑与统一管理 |
建议使用清晰的命名规则,便于管理:
[平台类型] - [站点特征] - [用途]
示例:
New API - 主站 - 生产环境OneHub - 备用 - 测试OpenAI - 官方 - 高优先级CPA - 本地 - 调试
- 国内访问 OpenAI / Claude / Gemini / 部分 OAuth provider: 通常需要代理
- 国内中转站: 通常不需要代理
- 海外中转站: 根据网络情况选择
- 远程 OAuth 部署: 除了代理,还要考虑回调端口连通性
- 每周检查: 账号健康状态、余额预警
- 每月清理: 禁用长期不可用的站点和账号
- 凭证轮换: 定期更新 Access Token 和 API Key
- 官方预设站点: 新增模型时记得补充推荐模型和 API 请求地址池
- 配置说明 — 环境变量与路由参数
- OAuth 管理 — Codex / Claude / Gemini CLI / Antigravity 授权接入
- 客户端接入 — 下游应用配置
- 常见问题 — 故障排查与优化建议
- 添加站点后,系统会自动发现可用模型并生成路由表,无需手动配置
- 支持同时接入多个相同类型的站点(如多个 New API 实例)
- 站点禁用后,关联的所有账号和路由通道会自动禁用
- 删除站点会级联删除所有关联账号、Token 和路由配置,请谨慎操作
- 如果你看到站点创建成功后的“官方预设”提示,请按它建议的下一步走,一般会更省事



