跳轉到主要內容

概覽

類型: 框架或平台主要路徑: OpenAI 相容預設支援級別: 推薦整合模式
對於 LemonData,Vercel AI SDK 中最穩定的預設選項是 OpenAI 相容供應商 如果你明確需要 Responses 原生 行為,可以切換到 OpenAI 供應商,並保持相同的 LemonData base URL。 請將本頁視為推薦整合模式,而不是「倉庫裡對 Vercel AI SDK 每個輔助函式都做了端到端回歸」的聲明。

建議的預設:OpenAI 相容供應商

npm install ai @ai-sdk/openai-compatible
import { createOpenAICompatible } from '@ai-sdk/openai-compatible';

export const lemondata = createOpenAICompatible({
  name: 'lemondata',
  apiKey: process.env.LEMONDATA_API_KEY,
  baseURL: 'https://api.lemondata.cc/v1',
});

產生文字

import { generateText } from 'ai';
import { lemondata } from './lemondata';

const { text } = await generateText({
  model: lemondata.chatModel('gpt-5.4'),
  prompt: 'Explain LemonData in one sentence.',
});

console.log(text);

串流文字

import { streamText } from 'ai';
import { lemondata } from './lemondata';

const result = await streamText({
  model: lemondata.chatModel('gpt-5.4'),
  prompt: 'Write a short poem about coding.',
});

for await (const textPart of result.textStream) {
  process.stdout.write(textPart);
}

工具呼叫

import { generateText, tool } from 'ai';
import { z } from 'zod';
import { lemondata } from './lemondata';

const result = await generateText({
  model: lemondata.chatModel('gpt-5.4'),
  prompt: 'What is the weather in San Francisco?',
  tools: {
    weather: tool({
      description: 'Get weather in a location',
      parameters: z.object({
        location: z.string(),
      }),
      execute: async ({ location }) => ({
        location,
        temperature: 72,
        condition: 'sunny',
      }),
    }),
  },
});

console.log(result.text);

結構化輸出

import { generateObject } from 'ai';
import { z } from 'zod';
import { lemondata } from './lemondata';

const { object } = await generateObject({
  model: lemondata.chatModel('gpt-5.4'),
  schema: z.object({
    name: z.string(),
    role: z.string(),
  }),
  prompt: 'Generate a fake developer profile.',
});

console.log(object);

如果你明確需要 Responses-Native 行為

npm install ai @ai-sdk/openai
import { createOpenAI } from '@ai-sdk/openai';

export const lemondataResponses = createOpenAI({
  apiKey: process.env.LEMONDATA_API_KEY,
  baseURL: 'https://api.lemondata.cc/v1',
});
import { generateText } from 'ai';
import { lemondataResponses } from './lemondata-responses';

const { text } = await generateText({
  model: lemondataResponses('gpt-5.4'),
  prompt: 'Explain LemonData in one sentence.',
});
@ai-sdk/openai-compatible 作為代理風格整合的安全預設選項。只有在你明確希望使用基於 /v1/responses 建立的供應商路徑時,才切換到 @ai-sdk/openai

環境變數

# .env.local
LEMONDATA_API_KEY=sk-your-lemondata-key

最佳實踐

對於第三方 gateway 和代理後端,@ai-sdk/openai-compatible 通常是最不容易出錯的起點。
如果你需要與 /v1/responses 綁定的供應商行為,請有意識地切換供應商套件,而不是在同一個用戶端中混用兩種模式。
絕不要在用戶端程式碼中暴露你的 LemonData API key。請將供應商設定放在伺服器檔案或 API 路由中。