Ephemeral tokens

Ephemeral tokens are short-lived authentication tokens for accessing the Gemini API through WebSockets . They are designed to enhance security when you are connecting directly from a user's device to the API (a client-to-server implementation). Like standard API keys, ephemeral tokens can be extracted from client-side applications such as web browsers or mobile apps. But because ephemeral tokens expire quickly and can be restricted, they significantly reduce the security risks in a production environment. You should use them when accessing the Live API directly from client-side applications to enhance API key security.

نحوه عملکرد توکن‌های زودگذر

در اینجا نحوه عملکرد توکن‌های زودگذر در سطح بالا آورده شده است:

  1. کلاینت شما (مثلاً برنامه وب) با backend شما احراز هویت می‌شود.
  2. بخش مدیریت شما یک توکن موقت از سرویس تأمین API مربوط به Gemini درخواست می‌کند.
  3. رابط برنامه‌نویسی نرم‌افزار Gemini یک توکن کوتاه‌مدت صادر می‌کند.
  4. بک‌اند شما توکن را برای اتصال WebSocket به Live API به کلاینت ارسال می‌کند. می‌توانید این کار را با تعویض کلید API خود با یک توکن موقت انجام دهید.
  5. سپس کلاینت از توکن مانند یک کلید API استفاده می‌کند.

مرور کلی توکن‌های زودگذر

این امر امنیت را افزایش می‌دهد زیرا حتی اگر استخراج شود، توکن برخلاف یک کلید API با عمر طولانی که در سمت کلاینت مستقر می‌شود، کوتاه‌مدت است. از آنجایی که کلاینت داده‌ها را مستقیماً به Gemini ارسال می‌کند، این امر همچنین تأخیر را بهبود می‌بخشد و از نیاز backend های شما به پروکسی کردن داده‌های بلادرنگ جلوگیری می‌کند.

یک توکن موقت ایجاد کنید

در اینجا یک مثال ساده از نحوه دریافت یک توکن موقت از Gemini آورده شده است. به طور پیش‌فرض، شما ۱ دقیقه فرصت دارید تا جلسات جدید Live API را با استفاده از توکن این درخواست ( newSessionExpireTime ) شروع کنید و ۳۰ دقیقه فرصت دارید تا پیام‌ها را از طریق آن اتصال ( expireTime ) ارسال کنید.

پایتون

import datetime

now = datetime.datetime.now(tz=datetime.timezone.utc)

client = genai.Client(
    http_options={'api_version': 'v1alpha',}
)

token = client.auth_tokens.create(
    config = {
    'uses': 1, # The ephemeral token can only be used to start a single session
    'expire_time': now + datetime.timedelta(minutes=30), # Default is 30 minutes in the future
    # 'expire_time': '2025-05-17T00:00:00Z',   # Accepts isoformat.
    'new_session_expire_time': now + datetime.timedelta(minutes=1), # Default 1 minute in the future
    'http_options': {'api_version': 'v1alpha'},
  }
)

# You'll need to pass the value under token.name back to your client to use it

جاوا اسکریپت

import { GoogleGenAI } from "@google/genai";

const client = new GoogleGenAI({});
const expireTime = new Date(Date.now() + 30 * 60 * 1000).toISOString();

  const token: AuthToken = await client.authTokens.create({
    config: {
      uses: 1, // The default
      expireTime: expireTime, // Default is 30 mins
      newSessionExpireTime: new Date(Date.now() + (1 * 60 * 1000)), // Default 1 minute in the future
      httpOptions: {apiVersion: 'v1alpha'},
    },
  });

برای محدودیت‌های مقدار expireTime ، مقادیر پیش‌فرض و سایر مشخصات فیلد، به مرجع API مراجعه کنید. در بازه زمانی expireTime ، برای اتصال مجدد تماس هر 10 دقیقه به sessionResumption نیاز خواهید داشت (این کار را می‌توان با همان توکن انجام داد، حتی اگر uses: 1 ).

همچنین می‌توان یک توکن موقت را به مجموعه‌ای از پیکربندی‌ها قفل کرد. این کار می‌تواند برای بهبود بیشتر امنیت برنامه شما و حفظ دستورالعمل‌های سیستم شما در سمت سرور مفید باشد.

پایتون

client = genai.Client(
    http_options={'api_version': 'v1alpha',}
)

token = client.auth_tokens.create(
    config = {
    'uses': 1,
    'live_connect_constraints': {
        'model': 'gemini-3.1-flash-live-preview',
        'config': {
            'session_resumption':{},
            'temperature':0.7,
            'response_modalities':['AUDIO']
        }
    },
    'http_options': {'api_version': 'v1alpha'},
    }
)

# You'll need to pass the value under token.name back to your client to use it

جاوا اسکریپت

import { GoogleGenAI } from "@google/genai";

const client = new GoogleGenAI({});
const expireTime = new Date(Date.now() + 30 * 60 * 1000).toISOString();

const token = await client.authTokens.create({
    config: {
        uses: 1, // The default
        expireTime: expireTime,
        liveConnectConstraints: {
            model: 'gemini-3.1-flash-live-preview',
            config: {
                sessionResumption: {},
                temperature: 0.7,
                responseModalities: ['AUDIO']
            }
        },
        httpOptions: {
            apiVersion: 'v1alpha'
        }
    }
});

// You'll need to pass the value under token.name back to your client to use it

همچنین می‌توانید زیرمجموعه‌ای از فیلدها را قفل کنید، برای اطلاعات بیشتر به مستندات SDK مراجعه کنید.

با یک توکن موقت به Live API متصل شوید

وقتی یک توکن موقت داشته باشید، می‌توانید از آن مانند یک کلید API استفاده کنید (اما به یاد داشته باشید، این توکن فقط برای API زنده و فقط با نسخه v1alpha آن API کار می‌کند).

استفاده از توکن‌های زودگذر تنها زمانی ارزش افزوده ایجاد می‌کند که برنامه‌هایی که از رویکرد پیاده‌سازی کلاینت به سرور پیروی می‌کنند، پیاده‌سازی شوند.

جاوا اسکریپت

import { GoogleGenAI, Modality } from '@google/genai';

// Use the token generated in the "Create an ephemeral token" section here
const ai = new GoogleGenAI({
  apiKey: token.name
});
const model = 'gemini-3.1-flash-live-preview';
const config = { responseModalities: [Modality.AUDIO] };

async function main() {

  const session = await ai.live.connect({
    model: model,
    config: config,
    callbacks: { ... },
  });

  // Send content...

  session.close();
}

main();

برای مثال‌های بیشتر ، به شروع کار با Live API مراجعه کنید.

بهترین شیوه‌ها

  • با استفاده از پارامتر expire_time مدت زمان انقضای کوتاهی را تنظیم کنید.
  • توکن‌ها منقضی می‌شوند و نیاز به شروع مجدد فرآیند تأمین دارند.
  • احراز هویت امن را برای backend خود تأیید کنید. توکن‌های موقت فقط به اندازه روش احراز هویت backend شما ایمن خواهند بود.
  • به طور کلی، از استفاده از توکن‌های زودگذر برای اتصالات backend به Gemini خودداری کنید، زیرا این مسیر معمولاً امن در نظر گرفته می‌شود.

محدودیت‌ها

توکن‌های موقت در حال حاضر فقط با Live API سازگار هستند.

قدم بعدی چیست؟

  • برای اطلاعات بیشتر، مرجع Live API در مورد توکن‌های موقت را مطالعه کنید.