集成指南
OpenAI Node / TypeScript SDK
在 Node、Bun、Deno 或浏览器中使用官方 openai npm 包对接 ToRouter。
官方 openai npm 包(v4+)无需改动即可对接 ToRouter——覆盖 baseURL、传入 ToRouter Key,就能调用目录中的任何模型。
配置
| 配置项 | 说明 |
|---|---|
| Base URL | https://portal.torouter.ai/v1 |
| API Key | sk-*** |
| 模型 | gpt-5、claude-opus-4-7、gemini-2.5-pro 等 |
SDK 也会从 process.env 读取 OPENAI_BASE_URL 和 OPENAI_API_KEY。
安装
npm install openai
# 或:pnpm add openai / bun add openai代码
import OpenAI from 'openai';
const client = new OpenAI({
baseURL: 'https://portal.torouter.ai/v1',
apiKey: 'sk-***',
});
const resp = await client.chat.completions.create({
model: 'gpt-5',
messages: [{ role: 'user', content: 'Hello' }],
});
console.log(resp.choices[0].message.content);import OpenAI from 'openai';
const client = new OpenAI({
baseURL: 'https://portal.torouter.ai/v1',
apiKey: 'sk-***',
});
const stream = await client.chat.completions.create({
model: 'claude-opus-4-7',
messages: [{ role: 'user', content: '用流式给我写一首俳句' }],
stream: true,
});
for await (const chunk of stream) {
process.stdout.write(chunk.choices[0]?.delta?.content ?? '');
}curl https://portal.torouter.ai/v1/chat/completions \
-H "Authorization: Bearer sk-***" \
-H "Content-Type: application/json" \
-d '{"model":"gpt-5","messages":[{"role":"user","content":"Hello"}]}'易踩的坑
- 选项名是
baseURL(驼峰),不是base_url。传 Python 风格的下划线写法会被静默忽略。 - 浏览器代码中只有在 ToRouter 已经配置好 Key 级 IP 白名单和速率限制后,才设置
dangerouslyAllowBrowser: true——浏览器里的 Key 会泄露到 Network 面板。 - Edge 运行时(Vercel Edge、Cloudflare Workers)可用;选用全局
fetch版本的 SDK,避免 Node-only 模块。