راهنمای ادغام موضوعات API

با نحوه استفاده از Topics API برای پاسخگویی به موارد خاص استفاده از فناوری تبلیغات آشنا شوید.

چگونه API موضوعات را برمی گرداند

اگر Chrome فاقد تعداد کافی موضوع مشاهده شده برای ایجاد پنج موضوع برتر برای یک دوره (یک هفته) باشد، آنگاه Topics API موضوعات تصادفی را برای تکمیل پنج موضوع برتر اضافه می کند. ستون Topics Internals با عنوان Real یا Random نشان می‌دهد که آیا آن موضوع خاص بر اساس یک مشاهده واقعی بوده است یا «بالا کردن» تصادفی اضافی برای تکمیل پنج مورد برتر. درباره این مکانیسم در توضیح بیشتر بخوانید.

موضوع انتخاب شده برای هر دوره به طور تصادفی از پنج موضوع برتر کاربر برای آن دوره انتخاب می شود. اگر موضوعات کافی در طول دوره مشاهده نشده باشد، موضوعات اضافی به طور تصادفی انتخاب می شوند تا مجموع پنج موضوع را تشکیل دهند. این موضوعات به طور تصادفی انتخاب شده در معرض فیلتر هستند.

برای افزایش بیشتر حریم خصوصی و اطمینان از اینکه همه موضوعات ممکن است نمایش داده شوند، احتمال 5٪ وجود دارد که موضوع انتخاب شده برای یک دوره به جای انتخاب از موضوعات مشاهده شده، به طور تصادفی از همه موضوعات انتخاب شود. همانطور که در مورد بالا که موضوعات بسیار کمی مشاهده شده بود، این موضوعات به طور تصادفی انتخاب شده در معرض فیلتر نیستند.

اطلاعات بیشتر در مورد نحوه انتخاب موضوعات در طبقه بندی موضوعات موجود است.

استقرار MVP خود را برنامه ریزی کنید

Topics API دسترسی به موضوعات مورد علاقه مشاهده شده برای کاربر را بدون نیاز به ردیابی سایت هایی که کاربر بازدید می کند، یا افشای تاریخچه پیمایش آنها می دهد.

تماس گیرنده Topics API نهادی است که متد جاوا اسکریپت document.browsingTopics() را فراخوانی می کند یا با استفاده از سرصفحه های درخواست HTTP موضوعات را مشاهده کرده و به آنها دسترسی پیدا می کند. کد شما، و eTLD+1 که از آن فراخوانی می شود، در این مثال، تماس گیرنده است. وقتی با Topics API تماس می‌گیرید، به مرورگر کاربر دستور می‌دهید که هنگام بازدید کاربر از یک وب‌سایت، موضوعات مورد علاقه را مشاهده کند. این بازدید سپس در محاسبه موضوعات برای دوره بعدی در نظر گرفته می شود.

Topics API برای فیلتر کردن نتایج به ازای هر تماس گیرنده یا هر eTLD+1 زمینه تماس طراحی شده است. به عبارت دیگر، مبدا iframe (هنگام استفاده از API جاوا اسکریپت) یا URL درخواست واکشی (در هنگام استفاده از هدر) تماس گیرنده در نظر گرفته می شود و موضوعات بر اساس آن تماس گیرنده محاسبه می شوند.

نمودار زیر این رویکرد را نشان می دهد:

مراحلی که Topics API هنگام بازدید کاربران از سایت‌هایی که از API استفاده می‌کنند، طی می‌کند.
نحوه مشاهده و دسترسی API به موضوعات

در این نمودار :

  1. کاربر Chrome را باز می‌کند و از چندین وب‌سایت (customerA.example، customerB.example.br، و غیره) بازدید می‌کند که شامل iframe فناوری تبلیغات شما (منبع: iframe.adtech.example) یا سرصفحه‌های ارسال تماس واکشی می‌شود.
    • Chrome موضوعات مورد علاقه این کاربر را ضبط می کند.
  2. پس از هفت روز پیمایش، با مشاهده موضوعات مورد علاقه توسط Topics API، همان کاربر در همان دستگاه از یک وب سایت مورد نظر (ناشر-e.example) بازدید می کند. Topics API لیستی از موضوعات را برمی گرداند و در این مثال خاص، یک موضوع محاسبه شده از هفته قبل از مشاهدات این کاربر برگردانده می شود.
    • فقط مرورگرهای کاربرانی که از سایت‌هایی بازدید کرده‌اند که adtech.example در مرحله 1 مشاهده کرده است، نتایج موضوعات را در مرحله 2 برمی‌گردانند (ما این را فیلتر مشاهده می‌نامیم—شما نمی‌توانید موضوعات کاربرانی را که قبلاً هرگز ندیده‌اید ببینید).
  3. با استفاده از این لیست (در حال حاضر یک موضوع) می توانید با API پشتیبان خود (ads.adtech.example/topics-backend) تماس بگیرید تا از داده های موضوعات به عنوان بخشی از مجموعه داده های متنی خود استفاده کنید.
  4. اکنون، بسته به مورد استفاده خود، می‌توانید با دسترسی به موضوعات مورد علاقه‌ای که در هفته‌های گذشته برای او مشاهده کرده‌اید، تجربه شخصی‌سازی‌شده‌تری برای این کاربر ایجاد کنید.

با Topics API تماس بگیرید

دو راه برای مشاهده و دسترسی به موضوعات برای کاربر وجود دارد. می توانید استفاده کنید

  • API جاوا اسکریپت از داخل یک iframe:
    • افزودن یک iframe در وب‌سایت‌های هدف (وب‌سایت‌های ناشر) که حاوی کد جاوا اسکریپت است که با استفاده از document.browsingTopics() Topics API را فراخوانی می‌کند.
  • گزینه هدر:
    • Fetch (که توصیه می‌شود) یا XHR ( توصیه نمی‌شود و فقط در طول کارآزمایی اصلی کامل در دسترس بود):
      • می‌توانید از سربرگ Sec-Browsing-Topics در درخواست‌ها به قسمت پشتی فناوری تبلیغات به موضوعات دسترسی داشته باشید. این کارآمدترین گزینه است (تأخیر کم برای مشاهده موضوعات یک کاربر خاص).
    • استفاده از تگ iframe با ویژگی browsingtopics :
      • می‌توانید یک iframe با ویژگی browsingtopics اضافه کنید و Chrome موضوعاتی را (که برای eTLD+1 iframe مشاهده می‌شود) در سرصفحه Sec-Browsing-Topics در درخواست iframe شامل می‌کند.

پیاده سازی با جاوا اسکریپت و iframes

توصیه می‌کنیم نسخه ی نمایشی Topics JavaScript API یا نسخه ی نمایشی هدر را فورش کنید و از یکی از این موارد به عنوان نقطه شروع کد خود استفاده کنید.

می توانید یک عنصر <iframe> را در HTML اضافه کنید یا یک iframe را به صورت پویا با جاوا اسکریپت اضافه کنید. یک راه برای ایجاد پویا یک iframe با جاوا اسکریپت زیر است:

const iframe = document.createElement('iframe');
iframe.setAttribute('src', 'https://...');
document.body.appendChild(iframe);

بررسی کنید که آیا Topics API در این دستگاه از طریق تشخیص ویژگی پشتیبانی می‌شود یا خیر:

'browsingTopics' in document && document.featurePolicy.allowsFeature('browsing-topics') ?
  console.log('document.browsingTopics() is supported on this page') :
  console.log('document.browsingTopics() is not supported on this page');

Topics API را از داخل آن iframe فراخوانی کنید:

const topics = await document.browsingTopics();

شما باید لیستی از موضوعات مشاهده شده برای این کاربر از سه هفته گذشته دریافت کنید. به یاد داشته باشید، این لیست می تواند خالی باشد یا ممکن است شامل 1، 2 یا 3 موضوع باشد، تا سه هفته گذشته.

در اینجا نمونه ای از آنچه API برمی گرداند آورده شده است:

[{'configVersion': String, 
  'modelVersion': String, 
  'taxonomyVersion': String, 
  'topic': Number, 
  'version': String}]
  • configVersion : رشته ای که پیکربندی فعلی را شناسایی می کند.
  • modelVersion : رشته ای که طبقه بندی کننده یادگیری ماشینی را که برای استنتاج موضوعات استفاده می شود، شناسایی می کند.
  • taxonomyVersion : رشته ای که مجموعه موضوعاتی را که در حال حاضر توسط مرورگر استفاده می شود، شناسایی می کند.
  • موضوع : عددی که موضوع را در طبقه بندی مشخص می کند.
  • نسخه : رشته ای که configVersion و modelVersion را ترکیب می کند.

در مورد این پیاده سازی بیشتر بخوانید.

با هدرهای HTTP پیاده سازی کنید

موضوعات را می توان از سربرگ Sec-Browsing-Topics درخواست fetch()/XHR یا درخواست iframe در دسترس قرار داد.

هدرهای درخواست و پاسخ برای تنظیم و بازیابی موضوعات.
هدرهای iframe و fetch() .

می توانید با تنظیم سرصفحه Observe-Browsing-Topics: ?1 در پاسخ به درخواست، موضوعات ارائه شده توسط سرصفحه های درخواست را به عنوان مشاهده علامت گذاری کنید. سپس مرورگر از آن موضوعات برای محاسبه موضوعات مورد علاقه کاربر استفاده می کند.

اگر API یک یا چند موضوع را برگرداند، یک درخواست واکشی به eTLD+1 که از آن موضوعات مشاهده شده‌اند، یک سرصفحه Sec-Browsing-Topics مانند زیر را شامل می‌شود:

(325);v=chrome.1:1:1, ();p=P000000000

اگر هیچ موضوعی توسط API برگردانده نشود، هدر به شکل زیر است:

();p=P0000000000000000000000000000000

مقادیر سرصفحه Sec-Browsing-Topics به منظور کاهش خطر یادگیری تعداد موضوعاتی که برای تماس گیرنده بر اساس طول سرصفحه در نظر گرفته شده است را کاهش می دهد.

پیاده سازی با fetch()

در صفحه ناشر، کد خود را برای درخواست واکشی اضافه کنید، و مطمئن شوید که {browsingTopics: true} را درج کنید.

fetch('<topics_caller_eTLD+1>', {browsingTopics: true})
    .then((response) => {
        // Process the response
 })

در مرورگرهایی که از API پشتیبانی می‌کنند، درخواست fetch() شامل سرصفحه Sec-Browsing-Topics می‌شود که موضوعات مشاهده‌شده برای نام میزبان URL درخواست را فهرست می‌کند.

با iframe پیاده سازی کنید

مشابه درخواست fetch() ، هدر Sec-Browsing-Topics هنگام استفاده از ویژگی browsingtopics در iframe ارسال می شود.

<iframe src="<topics_caller_eTLD+1>" browsingtopics></iframe>

در این مورد، تماس گیرنده خواهد بود، مشابه تماس واکشی.

سمت سرور - برای همه موارد یکسان است

برای اینکه عناوین موجود در هدر درخواست Sec-Browsing-Topics توسط مرورگر به صورت مشاهده شده علامت گذاری شوند، اما همچنین برای اینکه بازدید از صفحه فعلی را در محاسبه موضوع برتر دوره بعدی کاربر درج کند، پاسخ سرور باید شامل Observe-Browsing-Topics: ?1 .

در اینجا یک مثال جاوا اسکریپت با استفاده از setHeader() آورده شده است:

res.setHeader('Observe-Browsing-Topics', '?1');

موضوعات پیاده سازی back-end

افزودن یک انتهای پشتیبان برای موضوعات اختیاری است. انتخاب شما بستگی به نحوه و مکان استفاده از موضوعات محاسبه شده روی دستگاه (در مرورگر) دارد.

// Use the language/framework/stack of your preference
function processTopicsBackendAPI(topics, user, domain, caller) {
  // Validate inputs
  // If the list is not empty, continue
  // Use topics as an additional contextual signal
}

از موضوعات به عنوان داده های متنی استفاده کنید

داده‌های موضوعات را می‌توان در کنار سیگنال‌های دیگر مانند URL، کلمات کلیدی و حتی برچسب‌ها به عنوان سیگنالی اضافی درباره مخاطبان در نظر گرفت.

همانطور که در Maximize ad relevance بعد از کوکی های شخص ثالث توضیح داده شد، رویکردهای متعددی برای استفاده از موضوعات برای ارائه تبلیغات مرتبط وجود دارد. برخی از این موارد شامل استفاده از موضوعات برای ایجاد مخاطب است، و برخی دیگر استفاده از موضوعات را به عنوان یکی از سیگنال‌های دیگر برای آموزش مدل‌های یادگیری ماشینی پیشنهاد می‌کنند که برای استنباط علایق بیشتر مخاطبان یا حتی برای بهینه‌سازی منطق مناقصه استفاده می‌شوند.

ساخت و استقرار

  1. با مشاهده کاربران در تولید موضوعات را جمع آوری کنید—هنوز مقیاس بندی نشده است (زمان تخمینی: تقریباً 1 هفته)
    1. گزینه های خود را بدانید: iframe و جاوا اسکریپت یا هدرهای HTTP
    2. دامنه iframe را تعریف کنید.
    3. کد جاوا اسکریپت را با استفاده از برنامه آزمایشی به عنوان مرجع کد بسازید - یا گزینه هدر را پیاده سازی کنید.
    4. موضوعات را در محیط کنترل شده خود (برخی از سایت های تولید) مستقر کنید.
    5. پیاده سازی Topics را به برخی از سایت های هدف اضافه کنید (در حال حاضر بیش از پنج سایت نیست).
    6. تست عملکردی و اعتبار سنجی
  2. [اختیاری] از داده‌های موضوعات به‌عنوان سیگنال متنی (با نشانی‌های اینترنتی، برچسب‌ها و غیره) استفاده کنید (زمان تخمینی: حدود 3 روز).
    1. پس از دریافت لیست موضوعات، می توانید آن را با سایر سیگنال های متنی به انتهای خود ارسال کنید.

در برخی از سایت های هدف مستقر شود

اکنون که کد را در اختیار دارید، بیایید آن را برای اولین آزمایش به برخی از سایت های هدف اضافه کنیم و مطمئن شویم که API پایدار است و در این محیط کنترل شده کار می کند.

توصیه می کنیم وب سایت های هدفی را انتخاب کنید که:

  • تعداد کمی بازدید ماهانه دریافت کنید (کمتر از حدود 1 میلیون بازدید در ماه) : ابتدا باید API را برای یک مخاطب کوچک شروع کنید.
  • شما مالک و کنترل هستید : در صورت لزوم می توانید به سرعت پیاده سازی را بدون تأییدیه های پیچیده غیرفعال کنید.
  • کسب و کار حیاتی نیستند : از آنجایی که این پیاده سازی می تواند تجربه کاربر شما را مختل کند، با سایت های هدف کم خطر شروع کنید.
  • در مجموع بیش از پنج سایت نیست : در حال حاضر به ترافیک یا نوردهی زیادی نیاز ندارید.
  • نشان دادن تم های مختلف : وب سایت هایی را انتخاب کنید که دسته بندی های مختلفی را نشان می دهند (مثلاً یکی در مورد ورزش، دیگری درباره اخبار، یکی دیگر از غذا و نوشیدنی و غیره). می‌توانید از ابزار موضوعات داخلی در Chrome برای تأیید اعتبار دامنه‌ها و نحوه طبقه‌بندی آن‌ها توسط طبقه‌بندی‌کننده یادگیری ماشینی Topics استفاده کنید . در راهنمای توسعه‌دهنده Topics API درباره اشکال‌زدایی بیشتر بیاموزید.

تست عملکردی و اعتبار سنجی

هنگام فراخوانی Topics API در این محیط محدود می توانید انتظار داشته باشید:

  • آرایه خالی از موضوعات [] اگر این اولین تماس این دستگاه باشد، برای این سایت و تماس گیرنده در هفت روز گذشته.
  • فهرستی از صفر تا سه موضوع که نشان دهنده علایق این کاربر است.
  • پس از هفت روز مشاهده، باید دریافت کنید:
    • یک موضوع نشان دهنده علاقه آن کاربر است که از تاریخچه پیمایش آن هفته محاسبه شده است.
      • یک جزئیات مهم: اگر برای کاربر برای Topics API عناوین کافی برای محاسبه پنج موضوع برتر آن هفته توسط شما مشاهده نشده است، آنگاه Topics به تعداد مورد نیاز موضوع تصادفی را اضافه می کند تا به تعداد کل پنج موضوع برسد. جزئیات بیشتری درباره API بیابید.
  • اگر بعد از چهار هفته مشاهده با آن تماس می گیرید، یک موضوع جدید جایگزین یکی از سه مورد می شود.
    • این اتفاق می‌افتد زیرا Topics API برای هفته‌های بعد پایدار خواهد بود و بسیاری از علایق کاربر را آشکار نمی‌کند. جزئیات بیشتر را در GitHub بیابید.
  • اگر بیش از سه هفته موضوعاتی را برای کاربر مشاهده نکرده‌اید، آنگاه Topics API دوباره یک آرایه خالی [] را برمی‌گرداند.

عملکرد و معیارهای تجربه کاربری خود را اندازه گیری کنید.

  • زمان اجرای فراخوانی های جاوا اسکریپت به Topics API در داخل یک iframe متقاطع باید اندازه گیری شود تا در تجزیه و تحلیل عملکرد آینده مورد استفاده قرار گیرد - مطمئن شوید که داده های تله متری را به درستی در قسمت پشتی خود جمع آوری و ذخیره کرده اید.
    • زمان صرف شده برای ایجاد موضوعات iframe و postMessage() پس از دریافت موضوعات نیز معیار دیگری است که باید محاسبه شود.

عیب یابی

من با Topics API تماس می‌گیرم اما در نتیجه null دریافت می‌کنم. چه کاری می توانم انجام دهم؟
اگر در اولین هفته پس از مشاهده یک کاربر با Topics API تماس می‌گیرید، انتظار می‌رود.

توصیه های کلیدی

  1. کد جلویی خود را آزمایش کنید تا مطمئن شوید جاوا اسکریپت شما مطابق انتظار کار می کند.

  2. برای دریافت نتایج موضوعات پشتیبان خود را تست کنید.

    1. به یاد داشته باشید که مطمئن شوید انواع داده ها و پارامترهای API back-end به درستی پیکربندی شده اند.
    2. مطمئن شوید که قسمت پشتی شما برای مقیاس مناسب پیکربندی شده است.
  3. با توجه به تجربه ما، لازم است حداقل سه هفته قبل از شروع برای دریافت نتایج موضوعات مرتبط تر، فرصت دهیم.

  4. همه کاربران موضوعات را فعال نخواهند کرد:

    1. کاربران می توانند به صراحت API موضوعات را غیرفعال کنند.
    2. صفحات ناشر می توانند خط مشی مجوزها را کنترل کنند. به ( انصراف ) در راهنمای برنامه نویس Topics API مراجعه کنید.
    3. برای جزئیات بیشتر، chromestatus.com را بررسی کنید.
  5. معیارها و قابلیت مشاهده را به این محیط اضافه کنید: برای تجزیه و تحلیل اولین نتایج به آنها نیاز دارید. معیارهای نمونه عبارتند از:

    1. تأخیر تماس ها؛
    2. خطاهای HTTP در تماس های موضوعی؛
  6. سعی کنید تغییرات را در اجرای خود در سه هفته ابتدایی محدود کنید.

مقیاس به تولید

در اینجا یک خلاصه گام به گام از نحوه تولید مقیاس وجود دارد. مراحل در زیر توضیح داده شده است.

  1. مقیاس اجرا (تولید) در زیر توضیح داده شده است.
    1. iframe را به وب‌سایت‌های چند ناشر اضافه کنید.
  2. پردازش و استفاده از داده های موضوعات (زمان تخمینی: حدود 4 هفته).
    1. داده های موضوعات را به عنوان یک سیگنال افزودنی در کنار سایر داده ها ادغام کنید.
    2. شرکای آزمایشی مناقصه زمان واقعی را منبع کنید.
    3. تست ابزار را با موضوعات به عنوان سیگنال افزودنی برای داده های دیگر خود اجرا کنید.

اجرای خود را مقیاس بندی کنید

در این مرحله باید داده‌های موضوعاتی را داشته باشید که از برخی سایت‌ها در یک محیط کنترل‌شده جمع‌آوری می‌شوند، با سطح اطمینان بالاتری در مورد کل راه‌حل.

اکنون زمان آن رسیده است که این پیاده سازی را با استقرار همان کد در وب سایت های هدف بیشتری مقیاس بندی کنید. این به شما امکان می دهد تا کاربران بیشتری را مشاهده کنید، داده های موضوعات بیشتری را جمع آوری کنید و درک خود را از مخاطبان خود عمیق تر کنید.

ما موارد زیر را توصیه می کنیم:

  1. به تدریج در سراسر سایت خود مستقر شوید، به خصوص اگر حجم زیادی از ترافیک دارید.
  2. با توجه به ترافیک مورد انتظارتان، آزمایش بار را برای داده های موضوعات خود انجام دهید.
    1. اطمینان حاصل کنید که پشتیبان شما می تواند حجم زیادی از تماس ها را انجام دهد.
    2. مجموعه متریک و لاگ ها را برای تجزیه و تحلیل تنظیم کنید.
  3. بلافاصله پس از استقرار Topics API، معیارهای خود را بررسی کنید تا مشکلات شدید کاربر نهایی را شناسایی کنید. به طور مرتب معیارهای خود را بررسی کنید.
  4. در صورت بروز اختلال یا رفتار غیرمنتظره، استقرار را به عقب برگردانید و گزارش های خود را برای درک و رفع مشکل تجزیه و تحلیل کنید.

همچنین ببینید

برای درک بهتر Topics API در وب، منابع ما را بررسی کنید.