Skip to content

Latest commit

 

History

History
698 lines (462 loc) · 23.7 KB

File metadata and controls

698 lines (462 loc) · 23.7 KB

🔌 上游接入指南

本文档详细说明如何将不同类型的 AI 中转站、官方兼容入口和 OAuth 连接接入 Metapi。

返回文档中心


概述

Metapi 当前支持三类上游接入方式:

  1. 中转聚合平台 — New API / One API / OneHub / DoneHub / Veloera / AnyRouter / Sub2API / CPA 等
  2. 官方 API 端点 — OpenAI / Claude (Anthropic) / Gemini (Google) 直连
  3. 官方预设与 OAuth 连接 — Coding Plan / DeepSeek / Moonshot / MiniMax / ModelScope 等官方兼容入口,以及 Codex / Claude / Gemini CLI / Antigravity 的浏览器授权登录

其中:

  • 平台类型 决定协议适配和管理能力
  • 官方预设 还是落在 openai / claude 这类平台上,但会自动带出官方地址和推荐模型
  • OAuth 连接 不在「站点管理」里手填账号密码,而是在「OAuth 管理」里单独授权

每种接入方式略有不同,本文档按类型分别说明。


🎯 快速接入流程

通用步骤

  1. 登录管理后台 — 访问 http://your-metapi-host:4000,使用 AUTH_TOKEN 登录
  2. 进入站点管理 — 点击左侧菜单「站点管理」
  3. 添加站点 — 点击「添加站点」按钮
  4. 填写站点信息 — 根据站点类型填写对应字段;如果是官方入口,也可以直接选择预设
  5. 添加连接 — 按场景继续添加账号、API Key,或改去「OAuth 管理」授权
  6. 验证连接 — 系统自动验证账号可用性并获取模型列表

一句话判断该走哪条路

你手上有什么 推荐入口 推荐方式
有后台面板的聚合站 站点管理 先加站点,再加账号 / Session
只有 Base URL + API Key 的兼容接口 站点管理 先加站点,再加 API Key
官方 Coding / API 兼容入口 站点管理 直接选择官方预设
Codex / Claude / Gemini CLI / Antigravity 的 provider 账号 OAuth 管理 直接浏览器授权

📦 中转聚合平台接入

New API

适用平台: 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 支持三种凭证类型:

1. 用户名密码登录(推荐 AnyRouter 使用)
  • 适用场景: 有完整账号权限,需要自动签到、余额查询、账号令牌管理
  • 填写方式:
    • 用户名:your-username
    • 密码:your-password
  • 自动获取: 系统自动登录并获取 Access Token 和账号令牌
2. Access Token / Session Cookie
  • 适用场景: 已有登录凭证,无需密码
  • 填写方式:
    • 在「Access Token」字段填入以下任一格式:
      • Session Cookie:(最不推荐)
      • 可通过浏览器 F12 获取 Session Cookie 获取
      • 一般为如下格式:session=MTczNjQxMjM0NXxEdi1CQUFFQ180SUFBUkFCRUFBQVB2LUNBQUVHYzNSeWFXNW5EQThBRFhObGMzTnBiMjVmZEdGaWJHVUdjM1J5YVc1bkRBSUFBQT09fGRlYWRiZWVmMTIzNDU2Nzg5MGFiY2RlZjEyMzQ1Njc4OTBhYmNkZWY=
      • 系统访问令牌和用户 ID (推荐非 AnyRouter 的其他 New API 站点使用)
  • 自动解析: 系统自动识别凭证类型并提取用户信息
3. API Key(仅代理)
  • 适用场景: 仅用于模型调用,不需要余额管理、自动签到等功能
  • 填写方式:
    • 在「API Token」字段填入:sk-xxxxxxxxxxxxxx
  • 限制: 无法使用签到、余额刷新、账号令牌管理等功能

特殊说明

User ID 自动探测: New API 通常需要在请求头中携带 New-API-User / Veloera-User / voapi-user 等字段。Metapi 会自动:

  1. 从 JWT Token 中解码 User ID
  2. 从 Session Cookie 中提取 User ID(支持 Gob 编码解析)
  3. 通过探测常见 ID 范围验证可用性

如果以上方法都不能获取到 ID,则需要用户手动获取。

防护盾穿透: 自动处理阿里云盾 / Cloudflare 等 JS 挑战(acw_sc__v2 / cdn_sec_tc),无需手动配置。


One API

适用平台: One API 原版及兼容分支

站点配置

字段 说明 示例
站点名称 自定义名称 One API 主站
站点 URL One API 部署地址 https://oneapi.example.com
平台类型 选择 one-api -

账号凭证

One API 支持与 New API 相同的三种凭证类型(用户名密码 / Access Token / API Key),配置方式相同。


OneHub

适用平台: 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

适用平台: DoneHub(OneHub 增强分支)

站点配置

字段 说明 示例
站点名称 自定义名称 DoneHub 站点
站点 URL DoneHub 部署地址 https://donehub.example.com
平台类型 选择 done-hub -

账号凭证

DoneHub 完全兼容 OneHub 的凭证体系,配置方式相同,DoneHub 获取令牌位置如下图所示:DoneHub 令牌位置


Veloera

适用平台: Veloera API 网关

站点配置

字段 说明 示例
站点名称 自定义名称 Veloera 网关
站点 URL Veloera 部署地址 https://veloera.example.com
平台类型 选择 veloera -

账号凭证

Veloera 基于 New API 架构,支持相同的凭证类型。特别注意:

  • Veloera 需要 Veloera-User 请求头,Metapi 会自动添加

Sub2API

适用平台: Sub2API 订阅制中转平台

站点配置

字段 说明 示例
站点名称 自定义名称 Sub2API 订阅站
站点 URL Sub2API 部署地址 https://sub2api.example.com
平台类型 选择 sub2api -

账号凭证

Sub2API 常见 JWT 短期会话机制,和传统 NewAPI 站点差异较大。按下面步骤进行添加:

首先去中转站点 F12 打开如下界面:

Sub2API 认证字段示例

然后回到 Metapi 账号添加处:

Sub2API Session 配置

  1. 在「凭证模式」里选择 Session 模式,分别粘贴 F12 界面中的 auth_tokenrefresh_tokentoken_expires_at 字段进行验证,无需配置用户 ID。
  2. 不要使用账号密码登录,Metapi 不支持代替 Sub2API 做登录
  3. Sub2API 通常为订阅制使用,不支持签到;如果你只关心代理调用,也可以直接改用 API Key 模式
  4. GET /v1/models 为空,先确认该账号下已有可用用户 API Key,Metapi 会再尝试用它发现模型

CLIProxyAPI / CPA

适用平台: 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 或响应头被自动识别
  • 当前重点支持 模型发现代理调用
  • 不支持用户名密码登录、自动签到、站点余额 / 用户信息抓取

🌐 官方 API 端点接入

OpenAI

适用场景: 直连 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 无公开接口)
自动签到 ❌ 不适用
账号令牌管理 ❌ 不适用

Claude (Anthropic)

适用场景: 直连 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 模型。


Gemini (Google)

适用场景: 直连 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

使用建议

  1. 选中预设后,优先保留它自动填好的 URL
  2. 如果你只是接一个普通自建网关,不想保留预设语义,再手动改回通用 openai / claude
  3. 对官方预设来说,不要机械地把 /v1/anthropic 删掉,以预设默认值为准

🔐 OAuth 连接接入

有些 provider 更适合在左侧菜单 OAuth 管理 里直接授权,而不是在「站点管理 → 账号管理」里手填凭证。

当前推荐走 OAuth 的 provider

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 登录

什么时候应该走 OAuth

  • 你接的不是一个普通面板站,而是 provider 自己的账号
  • 你不想手填 Cookie / Session / API Key
  • 你希望后续刷新、重绑也继续走 provider 官方授权流程

使用建议

  1. 进入左侧菜单 OAuth 管理
  2. 选择对应 provider 发起授权
  3. 如果是远程部署,按页面提示使用 SSH 隧道或手动回填 callback URL
  4. 授权成功后,Metapi 会自动创建或复用对应站点与连接

完整流程见 OAuth 管理


🔧 高级配置

站点级代理

每个站点可单独配置代理,优先级高于全局 SYSTEM_PROXY_URL

站点专用代理 > 全局系统代理 > 直连

配置方式:

  1. 在站点编辑页面填写「代理 URL」字段
  2. 格式:http://proxy-host:portsocks5://proxy-host:port
  3. 支持 HTTP / HTTPS / SOCKS5 代理

站点权重

全局权重(global_weight): 影响该站点下所有通道的路由概率。

  • 默认值:1.0
  • 范围:0.1 ~ 10.0
  • 示例:
    • 设置为 2.0 — 该站点通道被选中的概率翻倍
    • 设置为 0.5 — 该站点通道被选中的概率减半

配置位置: 站点编辑页面 → 高级设置 → 全局权重

外部签到 URL

适用场景: 某些站点的签到接口非标准路径,或需要通过外部服务触发签到。

配置方式:

  1. 在站点编辑页面填写「外部签到 URL」
  2. Metapi 会向该 URL 发送 POST 请求执行签到
  3. 请求头自动携带账号凭证

API 请求地址池

现在不少站点已经不是“一个 URL 同时负责后台面板和 /v1/* API 请求”。

Metapi 当前支持把这两层拆开:

  • 主站点 URL:用于登录、签到、后台接口、系统访问令牌管理
  • API 请求地址池:用于真正转发 /v1/*/chat/completions/responses 等模型请求

适合填写 API 请求地址池的场景:

  1. 控制台地址和 API 网关地址不同
  2. 同一个站点有多个 API host,需要健康切换
  3. 你想保留面板地址不变,只把模型流量导向专用网关

简单理解:

主站点 URL = 控制面
API 请求地址池 = 数据面

🔍 站点自动检测

Metapi 支持自动识别站点类型,当前检测优先级如下:

1. 官方预设检测

下列地址会优先识别成官方预设,并返回 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 强制自动识别,更适合手动选预设。

2. 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

3. 页面标题检测

访问站点首页,解析 <title> 标签识别平台类型。

4. API 探测

依次尝试各平台的特征接口:

  • 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 的公告列表

行为约定:

  1. 首次发现的公告会触发一次 Metapi 通知
  2. 已经保存过的公告再次同步时只更新本地记录
  3. sub2api 这类需要登录态的公告接口,会优先使用站点下已启用账号的会话令牌
  4. 「站点公告」页面的清空操作只影响 Metapi 本地数据库

🛠️ 故障排查

问题:添加站点后无法获取模型列表

可能原因:

  1. 站点 URL 填写错误
    • 通用平台常见是填根地址,错误地带上了不该带的 /v1
    • 官方预设则相反,不要把预设自动带出的 /v1 / /anthropic / /api/coding/... 手动删掉
  2. 网络不通(检查代理配置或防火墙)
  3. 凭证无效(重新验证账号密码、Session 或 API Key)
  4. 主站点 URL 和真实 API 请求地址不同,但还没配置 API 请求地址池

解决方法:

  • 在站点详情页点击「测试连接」
  • 查看「事件日志」中的错误信息
  • 检查「代理日志」中的请求详情

问题:New API 账号提示「需要 New-API-User 头」

原因: 该站点是 New API 衍生版本,需要 User ID。

解决方法:

  1. Metapi 会自动探测 User ID,通常无需手动配置

  2. 如果自动探测失败,可在账号编辑页面的「额外配置」中手动填写:

    {
      "platformUserId": 12345
    }

问题:CPA 为什么没有账号登录、签到、余额刷新

原因: cliproxyapi / CPA 在 Metapi 里按标准 API provider 处理,重点支持模型发现与代理调用,不按传统面板站处理。

解决方法:

  • 直接使用 API Key 模式
  • 不要再按「用户名密码登录 + 自动签到」的思路排查

问题:什么时候不该再用账号管理,而应该去 OAuth 管理

原因: 你接的不是普通面板站,而是 provider 自己的授权账号。

解决方法:

  • Codex / Claude / Gemini CLI / Antigravity 这类连接直接去左侧 OAuth 管理
  • 不要在账号管理里反复尝试 Cookie / Session / API Key 兜底

问题:签到失败

可能原因:

  1. 凭证过期(Access Token 有效期到期)
  2. 站点签到接口变更
  3. 已经签到过(部分站点限制每日一次)

解决方法:

  • 查看「签到记录」中的失败原因
  • 尝试重新登录获取新凭证
  • 配置「外部签到 URL」使用备用签到方式

问题:余额显示不准确

原因: 不同平台的余额单位不同。

说明:

  • New API 系列:余额单位为「美元」,内部存储为 quota / 500000
  • OpenAI / Claude / Gemini / CPA:官方或兼容 API 通常无余额查询接口,显示为 N/A

📝 最佳实践

1. 凭证选择建议

场景 推荐凭证类型 原因
个人站点,需要完整功能 用户名密码 / Access Token 支持自动签到、账号令牌管理
共享账号,只读权限 Access Token 避免密码泄露
仅用于模型调用 API Token 最小权限原则
Provider 原生账号 OAuth 更适合后续刷新、重绑与统一管理

2. 站点命名规范

建议使用清晰的命名规则,便于管理:

[平台类型] - [站点特征] - [用途]

示例:

  • New API - 主站 - 生产环境
  • OneHub - 备用 - 测试
  • OpenAI - 官方 - 高优先级
  • CPA - 本地 - 调试

3. 代理配置策略

  • 国内访问 OpenAI / Claude / Gemini / 部分 OAuth provider: 通常需要代理
  • 国内中转站: 通常不需要代理
  • 海外中转站: 根据网络情况选择
  • 远程 OAuth 部署: 除了代理,还要考虑回调端口连通性

4. 定期维护

  • 每周检查: 账号健康状态、余额预警
  • 每月清理: 禁用长期不可用的站点和账号
  • 凭证轮换: 定期更新 Access Token 和 API Key
  • 官方预设站点: 新增模型时记得补充推荐模型和 API 请求地址池

🔗 相关文档


💡 提示

  • 添加站点后,系统会自动发现可用模型并生成路由表,无需手动配置
  • 支持同时接入多个相同类型的站点(如多个 New API 实例)
  • 站点禁用后,关联的所有账号和路由通道会自动禁用
  • 删除站点会级联删除所有关联账号、Token 和路由配置,请谨慎操作
  • 如果你看到站点创建成功后的“官方预设”提示,请按它建议的下一步走,一般会更省事