跳转到主要内容
LemonData 支持 Gemini 模型的原生 Google Gemini API 格式。这使得它能够直接兼容 Google AI SDK。

路径参数

model
string
必填
模型名称(例如:gemini-2.5-progemini-2.5-flash)。

查询参数

key
string
API key(请求头身份验证的替代方案)。

身份验证

Gemini 端点支持多种身份验证方法:
  • ?key=YOUR_API_KEY 查询参数
  • x-goog-api-key: YOUR_API_KEY 请求头
  • Authorization: Bearer YOUR_API_KEY 请求头

请求体

contents
array
必填
对话内容。每个内容对象包含:
  • role (string):usermodel
  • parts (array):内容 part。LemonData 当前支持:
    • 文本 part:{ "text": "..." }
    • 内联媒体 part:inlineData / inline_data
    • 基于 URL 的文件 part:fileData / file_data
对于媒体 part,LemonData 当前接受图片、音频、视频三类 MIME type,并通过 Gemini 兼容公共契约向下游透传。 在生产集成中,建议优先使用带公开 https URL 的 fileData / file_data 形式。 当底层物理路由已通过 Gemini-native 多模态验证时,LemonData 会优先走原生 Gemini 路径;否则会自动回退到兼容转换路径,无需调用方感知底层渠道差异。
systemInstruction
object
模型的系统指令。
generationConfig
object
生成配置:
  • temperature (number): 采样温度
  • topP (number): 核采样概率
  • topK (integer): Top-K 采样
  • maxOutputTokens (integer): 最大输出 token 数
  • stopSequences (array): 停止序列
safetySettings
array
安全过滤设置。

响应

candidates
array
生成的候选内容。
usageMetadata
object
Token 使用信息。
curl -X POST "https://api.lemondata.cc/v1beta/models/gemini-2.5-pro:generateContent?key=sk-your-api-key" \
  -H "Content-Type: application/json" \
  -d '{
    "contents": [
      {
        "parts": [{"text": "Hello, Gemini!"}]
      }
    ],
    "generationConfig": {
      "temperature": 0.7,
      "maxOutputTokens": 1024
    }
  }'

多模态输入示例

对于 Gemini 多模态请求,请把媒体放到 contents[].parts[] 中,可以使用“内联字节”或“基于 URL 的文件引用”两种方式。 当前公共 Gemini 契约支持的媒体类别:
  • 图片
  • 音频
  • 视频
对于内联媒体,使用 inlineDatainline_data,并传入文件字节的 Base64 内容。 对于 URL 媒体,使用 fileDatafile_data,并传入一个可公开访问的 https URL。

视频输入示例

{
  "contents": [
    {
      "role": "user",
      "parts": [
        { "text": "请描述这个视频。" },
        {
          "fileData": {
            "mimeType": "video/mp4",
            "fileUri": "https://example.com/demo.mp4"
          }
        }
      ]
    }
  ]
}

音频输入示例

{
  "contents": [
    {
      "role": "user",
      "parts": [
        { "text": "请描述这段音频。" },
        {
          "fileData": {
            "mimeType": "audio/mpeg",
            "fileUri": "https://example.com/demo.mp3"
          }
        }
      ]
    }
  ]
}

图片输入示例

使用内联图片字节:
{
  "contents": [
    {
      "role": "user",
      "parts": [
        { "text": "请描述这张图片。" },
        {
          "inlineData": {
            "mimeType": "image/jpeg",
            "data": "/9j/4AAQSkZJRgABAQ..."
          }
        }
      ]
    }
  ]
}
使用图片 URL:
{
  "contents": [
    {
      "role": "user",
      "parts": [
        { "text": "请描述这张图片。" },
        {
          "fileData": {
            "mimeType": "image/jpeg",
            "fileUri": "https://example.com/demo.jpg"
          }
        }
      ]
    }
  ]
}

音频输入示例

{
  "contents": [
    {
      "role": "user",
      "parts": [
        { "text": "请转写并总结这段音频。" },
        {
          "file_data": {
            "mime_type": "audio/mpeg",
            "file_uri": "https://example.com/sample.mp3"
          }
        }
      ]
    }
  ]
}

视频输入示例

{
  "contents": [
    {
      "role": "user",
      "parts": [
        { "text": "请简要描述这段视频。" },
        {
          "fileData": {
            "mimeType": "video/mp4",
            "fileUri": "https://example.com/sample.mp4"
          }
        }
      ]
    }
  ]
}
{
  "candidates": [
    {
      "content": {
        "role": "model",
        "parts": [
          {"text": "Hello! How can I assist you today?"}
        ]
      },
      "finishReason": "STOP",
      "safetyRatings": [
        {"category": "HARM_CATEGORY_HARASSMENT", "probability": "NEGLIGIBLE"}
      ]
    }
  ],
  "usageMetadata": {
    "promptTokenCount": 5,
    "candidatesTokenCount": 10,
    "totalTokenCount": 15
  }
}