تتيح لك أداة "سياق عنوان URL" تقديم سياق إضافي للنماذج في شكل عناوين URL. من خلال تضمين عناوين URL في طلبك، سيتمكّن النموذج من الوصول إلى المحتوى من تلك الصفحات (ما دام نوع عنوان URL غير مدرَج في قسم القيود) للاستناد إليه وتحسين رده.
تفيد أداة سياق عنوان URL في مهام مثل ما يلي:
- استخراج البيانات: استخراج معلومات معيّنة، مثل الأسعار أو الأسماء أو النتائج الرئيسية، من عناوين URL متعددة
- مقارنة المستندات: يمكنك تحليل تقارير أو مقالات أو ملفات PDF متعددة لتحديد الاختلافات وتتبُّع المؤشرات.
- تجميع المحتوى وإنشاؤه: يمكنك الجمع بين المعلومات من عدة عناوين URL مصدرية لإنشاء ملخّصات أو منشورات مدوّنات أو تقارير دقيقة.
- تحليل الرموز البرمجية والمستندات: يمكنك الإشارة إلى مستودع GitHub أو مستندات فنية لشرح الرموز البرمجية أو إنشاء تعليمات الإعداد أو الإجابة عن الأسئلة.
يوضّح المثال التالي كيفية مقارنة وصفتَي طعام من موقعَين إلكترونيَين مختلفَين.
Python
from google import genai
from google.genai.types import Tool, GenerateContentConfig
client = genai.Client()
model_id = "gemini-2.5-flash"
tools = [
{"url_context": {}},
]
url1 = "https://www.foodnetwork.com/recipes/ina-garten/perfect-roast-chicken-recipe-1940592"
url2 = "https://www.allrecipes.com/recipe/21151/simple-whole-roast-chicken/"
response = client.models.generate_content(
model=model_id,
contents=f"Compare the ingredients and cooking times from the recipes at {url1} and {url2}",
config=GenerateContentConfig(
tools=tools,
)
)
for each in response.candidates[0].content.parts:
print(each.text)
# For verification, you can inspect the metadata to see which URLs the model retrieved
print(response.candidates[0].url_context_metadata)
JavaScript
import { GoogleGenAI } from "@google/genai";
const ai = new GoogleGenAI({});
async function main() {
const response = await ai.models.generateContent({
model: "gemini-2.5-flash",
contents: [
"Compare the ingredients and cooking times from the recipes at https://www.foodnetwork.com/recipes/ina-garten/perfect-roast-chicken-recipe-1940592 and https://www.allrecipes.com/recipe/21151/simple-whole-roast-chicken/",
],
config: {
tools: [{urlContext: {}}],
},
});
console.log(response.text);
// For verification, you can inspect the metadata to see which URLs the model retrieved
console.log(response.candidates[0].urlContextMetadata)
}
await main();
REST
curl "https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent" \
-H "x-goog-api-key: $GEMINI_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"contents": [
{
"parts": [
{"text": "Compare the ingredients and cooking times from the recipes at https://www.foodnetwork.com/recipes/ina-garten/perfect-roast-chicken-recipe-1940592 and https://www.allrecipes.com/recipe/21151/simple-whole-roast-chicken/"}
]
}
],
"tools": [
{
"url_context": {}
}
]
}' > result.json
cat result.json
آلية العمل
تستخدم أداة "سياق عنوان URL" عملية استرجاع من خطوتَين لتحقيق التوازن بين السرعة والتكلفة والوصول إلى البيانات الحديثة. عند تقديم عنوان URL، تحاول الأداة أولاً جلب المحتوى من ذاكرة تخزين مؤقت للفهرس الداخلي. ويعمل ذلك كذاكرة تخزين مؤقت محسّنة للغاية. إذا لم يكن عنوان URL متاحًا في الفهرس (على سبيل المثال، إذا كانت الصفحة جديدة جدًا)، ستعود الأداة تلقائيًا إلى إجراء عملية جلب مباشرة. يصل هذا الإجراء مباشرةً إلى عنوان URL لاسترداد محتواه في الوقت الفعلي.
الدمج مع أدوات أخرى
يمكنك الجمع بين أداة سياق عنوان URL وأدوات أخرى لإنشاء سير عمل أكثر فعالية.
تحديد المصادر باستخدام "بحث Google"
عند تفعيل كلّ من "سياق عنوان URL" وتحديد مصدر المعلومات باستخدام "بحث Google"، يمكن للنموذج استخدام إمكانات البحث للعثور على معلومات ذات صلة على الإنترنت، ثم استخدام أداة "سياق عنوان URL" للتعرّف بشكل أكثر تفصيلاً على الصفحات التي يعثر عليها. هذا الأسلوب فعّال في الطلبات التي تتطلّب البحث على نطاق واسع والتحليل المتعمّق لصفحات معيّنة.
Python
from google import genai
from google.genai.types import Tool, GenerateContentConfig, GoogleSearch, UrlContext
client = genai.Client()
model_id = "gemini-2.5-flash"
tools = [
{"url_context": {}},
{"google_search": {}}
]
response = client.models.generate_content(
model=model_id,
contents="Give me three day events schedule based on YOUR_URL. Also let me know what needs to taken care of considering weather and commute.",
config=GenerateContentConfig(
tools=tools,
)
)
for each in response.candidates[0].content.parts:
print(each.text)
# get URLs retrieved for context
print(response.candidates[0].url_context_metadata)
JavaScript
import { GoogleGenAI } from "@google/genai";
const ai = new GoogleGenAI({});
async function main() {
const response = await ai.models.generateContent({
model: "gemini-2.5-flash",
contents: [
"Give me three day events schedule based on YOUR_URL. Also let me know what needs to taken care of considering weather and commute.",
],
config: {
tools: [
{urlContext: {}},
{googleSearch: {}}
],
},
});
console.log(response.text);
// To get URLs retrieved for context
console.log(response.candidates[0].urlContextMetadata)
}
await main();
REST
curl "https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash:generateContent" \
-H "x-goog-api-key: $GEMINI_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"contents": [
{
"parts": [
{"text": "Give me three day events schedule based on YOUR_URL. Also let me know what needs to taken care of considering weather and commute."}
]
}
],
"tools": [
{
"url_context": {}
},
{
"google_search": {}
}
]
}' > result.json
cat result.json
فهم الردّ
عندما يستخدم النموذج أداة "سياق عنوان URL"، يتضمّن الردّ عنصر url_context_metadata. يسرد هذا العنصر عناوين URL التي استردّ منها النموذج المحتوى وحالة كل محاولة استرداد، ما يفيد في التحقّق من صحة النتائج وتصحيح الأخطاء.
في ما يلي مثال على هذا الجزء من الرد (تم حذف أجزاء من الرد للاختصار):
{
"candidates": [
{
"content": {
"parts": [
{
"text": "... \n"
}
],
"role": "model"
},
...
"url_context_metadata": {
"url_metadata": [
{
"retrieved_url": "https://www.foodnetwork.com/recipes/ina-garten/perfect-roast-chicken-recipe-1940592",
"url_retrieval_status": "URL_RETRIEVAL_STATUS_SUCCESS"
},
{
"retrieved_url": "https://www.allrecipes.com/recipe/21151/simple-whole-roast-chicken/",
"url_retrieval_status": "URL_RETRIEVAL_STATUS_SUCCESS"
}
]
}
}
}
للحصول على تفاصيل كاملة حول هذا العنصر، يُرجى الاطّلاع على
مرجع واجهة برمجة التطبيقات UrlContextMetadata.
عمليات التحقّق من الأمان
يُجري النظام عملية تدقيق في المحتوى على عنوان URL للتأكّد من استيفائه معايير الأمان. إذا لم يجتَز عنوان URL الذي قدّمته عملية التحقّق هذه، سيظهر لك url_retrieval_status من URL_RETRIEVAL_STATUS_UNSAFE.
عدد الرموز المميّزة
يتم احتساب المحتوى الذي يتم استرجاعه من عناوين URL التي تحدّدها في طلبك كجزء من الرموز المميزة للإدخال. يمكنك الاطّلاع على عدد الرموز المميزة للطلب واستخدام الأدوات في عنصر usage_metadata من ناتج النموذج. في ما يلي مثال على الناتج:
'usage_metadata': {
'candidates_token_count': 45,
'prompt_token_count': 27,
'prompt_tokens_details': [{'modality': <MediaModality.TEXT: 'TEXT'>,
'token_count': 27}],
'thoughts_token_count': 31,
'tool_use_prompt_token_count': 10309,
'tool_use_prompt_tokens_details': [{'modality': <MediaModality.TEXT: 'TEXT'>,
'token_count': 10309}],
'total_token_count': 10412
}
يعتمد السعر لكل رمز مميز على النموذج المستخدَم، راجِع صفحة الأسعار للحصول على التفاصيل.
النماذج المتوافقة
أفضل الممارسات
- تقديم عناوين URL محدّدة: للحصول على أفضل النتائج، قدِّم عناوين URL مباشرة إلى المحتوى الذي تريد أن يحلّله النموذج. لن يستردّ النموذج المحتوى إلا من عناوين URL التي تقدّمها، وليس من أي محتوى من الروابط المتداخلة.
- التحقّق من إمكانية الوصول: تأكَّد من أنّ عناوين URL التي تقدّمها لا تؤدي إلى صفحات تتطلّب تسجيل الدخول أو تقع خلف حاجز دفع.
- استخدام عنوان URL الكامل: يجب تقديم عنوان URL الكامل، بما في ذلك البروتوكول (مثلاً، https://www.google.com بدلاً من google.com فقط).
القيود
- استدعاء الدوال: لا تتوفّر حاليًا إمكانية استخدام الأدوات (مثل "سياق عنوان URL" و"تحديد المصدر باستخدام بحث Google" وما إلى ذلك) مع استدعاء الدوال.
- حدّ الطلب: يمكن للأداة معالجة ما يصل إلى 20 عنوان URL لكل طلب.
- حجم محتوى عنوان URL: الحد الأقصى لحجم المحتوى الذي يتم استرجاعه من عنوان URL واحد هو 34 ميغابايت.
أنواع المحتوى المتوفّرة وغير المتوفّرة
يمكن للأداة استخراج المحتوى من عناوين URL التي تتضمّن أنواع المحتوى التالية:
- نص (text/html أو application/json أو text/plain أو text/xml أو text/css أو text/javascript أو text/csv أو text/rtf)
- صورة (image/png أو image/jpeg أو image/bmp أو image/webp)
- PDF (application/pdf)
لا تتوافق أنواع المحتوى التالية:
- المحتوى المحمي بنظام حظر الاشتراك غير المدفوع
- فيديوهات YouTube (راجِع مقالة فهم الفيديو للتعرّف على كيفية معالجة عناوين URL الخاصة بفيديوهات YouTube)
- ملفات Google Workspace، مثل مستندات Google أو جداول البيانات
- ملفات الفيديو والصوت
الخطوات التالية
- يمكنك الاطّلاع على كتاب وصفات سياق عنوان URL للحصول على المزيد من الأمثلة.