Руководство разработчика API тем

Узнайте, как работать с API, в том числе как использовать флаги Chrome для тестирования.

Статус реализации

  • API Topics прошел стадию публичного обсуждения и в настоящее время доступен 99 процентам пользователей с возможностью масштабирования до 100 процентов.
  • Чтобы оставить свой отзыв об API тем, создайте проблему в объяснителе тем или примите участие в обсуждениях в бизнес-группе улучшения веб-рекламы . У объяснителя остается ряд открытых вопросов, которые еще требуют дальнейшего уточнения.
  • В графике Privacy Sandbox указаны сроки реализации Topics API и других предложений Privacy Sandbox.
  • API Topics: в последних обновлениях подробно описаны изменения и улучшения API Topics и их реализации.

Попробуйте демо

Существует две демо-версии API Topics, которые позволяют опробовать Topics в качестве одного пользователя.

Вы также можете запустить совместную работу Topics, чтобы опробовать модель классификатора Topics.

Используйте API JavaScript для доступа к темам и записывайте их в соответствии с наблюдениями.

API Topics JavaScript имеет один метод: document.browsingTopics() . Это имеет две цели:

  • Укажите браузеру, чтобы он записал текущее посещение страницы как наблюдаемое для вызывающего абонента, чтобы впоследствии это можно было использовать для расчета тем для пользователя (для вызывающего абонента).
  • Доступ к темам пользователя, которые наблюдал вызывающий абонент.

Метод возвращает обещание, которое разрешается в массив из трех тем, по одной для каждой из трех последних эпох , в случайном порядке. Эпоха — это период времени, равный одной неделе в реализации Chrome.

Каждый объект темы в массиве, возвращаемом document.browsingTopics() имеет следующие свойства:

  • configVersion : строка, идентифицирующая текущую конфигурацию API тем, например chrome.2
  • modelVersion : строка, идентифицирующая классификатор машинного обучения, используемый для определения тем для сайта, например 4
  • taxonomyVersion : строка, определяющая набор тем, используемых браузером, например 2
  • topic : номер, идентифицирующий тему в таксономии , например 309
  • version : строка, объединяющая configVersion , taxonomyVersion и modelVersion , например chrome.2:2:4

Параметры, описанные в этом руководстве, и детали API (например, размер таксономии, количество тем, рассчитываемых в неделю, и количество тем, возвращаемых за один вызов) могут быть изменены по мере того, как мы учитываем отзывы экосистемы и совершенствуем API.

Обнаружение поддержки document.browsingTopics

Прежде чем использовать 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');

Доступ к темам с помощью JavaScript API

Вот базовый пример возможного использования API для доступа к темам текущего пользователя.

try {
  // Get the array of top topics for this user.
  const topics = await document.browsingTopics();
  
  // Request an ad creative, providing topics information.
  const response = await fetch('https://ads.example/get-creative', {
   method: 'POST',
   headers: {
     'Content-Type': 'application/json',
   },
   body: JSON.stringify(topics)
  })
  
  // Get the JSON from the response.
  const creative = await response.json();
  
  // Display ad.

} catch (error) {
  // Handle error.
}

Доступ к темам без изменения состояния

document.browsingTopics() возвращает темы, наблюдаемые вызывающей стороной для текущего пользователя. По умолчанию этот метод также заставляет браузер записывать текущее посещение страницы, наблюдаемое вызывающим объектом, поэтому его позже можно использовать при вычислении тем. В Chrome 108 методу можно передать необязательный аргумент, чтобы пропустить запись посещения страницы: {skipObservation:true} .

Другими словами, {skipObservation:true} означает, что вызов метода не приведет к включению текущей страницы в расчет тем.

Используйте заголовки для доступа к темам и отмечайте их как наблюдаемые.

Вы можете получить доступ к темам, а также отметить посещения страниц как наблюдаемые с помощью заголовков запросов и ответов .

Использование подхода с заголовком может быть гораздо более производительным, чем использование API JavaScript, поскольку API требует создания iframe с перекрестным происхождением и выполнения из него вызова document.browsingTopics() . (Для вызова необходимо использовать iframe с перекрестным происхождением, поскольку контекст, из которого вызывается API, используется для обеспечения того, чтобы браузер возвращал темы, соответствующие вызывающему объекту.) В объяснителе тем есть дальнейшее обсуждение: Должен ли быть способ отправлять темы, используя Fetch в качестве заголовка запроса? .

Доступ к темам можно получить из заголовка Sec-Browsing-Topics запроса fetch() или XHR .

Установка заголовка Observe-Browsing-Topics: ?1 в ответе на запрос заставляет браузер записывать текущее посещение страницы, наблюдаемое вызывающим абонентом, поэтому его позже можно использовать при вычислении тем.

Доступ к темам и их просмотр с помощью HTTP-заголовков можно получить двумя способами:

  • fetch() : добавьте {browsingTopics: true} в параметр options запроса fetch() . Демонстрационный заголовок Topics показывает упрощенный пример этого.
  • Атрибут iframe : добавьте атрибут browsingtopics к элементу <iframe> или установите эквивалентное свойство JavaScript iframe.browsingTopics = true . Регистрируемый домен источника iframe — это домен вызывающей стороны: например, для <iframe src="https://example.com" browsingtopics></iframe> : вызывающая сторона — example.com .

Некоторые дополнительные примечания о заголовках:

  • Перенаправления будут отслеживаться, и темы, отправленные в запросе на перенаправление, будут специфичными для URL-адреса перенаправления.
  • Заголовок запроса не изменит состояние вызывающего абонента, если не существует соответствующего заголовка ответа. То есть без заголовка ответа посещение страницы не будет записано как наблюдаемое, поэтому оно не повлияет на расчет темы пользователя для следующей эпохи.
  • Заголовок ответа учитывается только в том случае, если соответствующий запрос включал заголовок темы.
  • URL-адрес запроса предоставляет регистрируемый домен, который записывается как домен вызывающего абонента.

Отладка реализации API

Страница chrome://topics-internals доступна в Chrome на компьютере после включения API тем . Здесь отображаются темы для текущего пользователя, темы, предполагаемые для имен хостов, а также техническая информация о реализации API. Мы дорабатываем и улучшаем дизайн страницы на основе отзывов разработчиков: оставляйте свои отзывы на bugs.chromium.org .

Просмотр тем, рассчитанных для вашего браузера

Пользователи могут просматривать информацию о темах, наблюдаемых в их браузере в текущую и предыдущую эпохи, открыв chrome://topics-internals .

Страница chrome://topics-internals с выбранной панелью «Состояние тем».
На странице chrome://topics-internals на панели «Состояние тем» отображаются идентификаторы тем, случайные и реальные назначения тем, а также таксономия и версии модели.

На этом снимке экрана показано, что недавно посещенные сайты включают в себя topics-demo-cats.glitch.me и cats-cats-cats-cats.glitch.me . Это приводит к тому, что API тем выбирает Pets и Cats в качестве двух главных тем текущей эпохи. Остальные три темы были выбраны случайным образом , так как истории просмотров (на сайтах, наблюдающих за темами) недостаточно для предоставления пяти тем.

Столбец «Обсервируемые контекстные домены (хешированные)» предоставляет хешированное значение имени хоста, для которого наблюдалась тема.

Просмотр тем, предполагаемых для имен хостов

Вы также можете просмотреть темы, определенные моделью классификатора тем для одного или нескольких имен хостов в chrome://topics-internals .

Страница chrome://topics-internals с выбранной панелью «Классификатор».
На панели классификатора страницы chrome://topics-internals отображаются выбранные темы, посещенные хосты, а также версия и путь модели.

Текущая реализация Topics API определяет темы только по именам хостов; а не из какой-либо другой части URL-адреса.

Используйте только имена хостов (без протокола или пути) для просмотра тем, выведенных из классификатора chrome://topics-internals . chrome://topics-internals отобразит ошибку, если вы попытаетесь добавить «/» в поле «Хост».

Просмотр информации об API тем

Информацию о реализации и настройках Topics API, например о версии таксономии и продолжительности эпохи, можно найти в chrome://topics-internals . Эти значения отражают настройки по умолчанию для API или параметры, успешно установленные из командной строки . Это может быть полезно для подтверждения того, что флаги командной строки работают должным образом.

, , ,

В примере time_period_per_epoch установлено на 15 секунд (по умолчанию — семь дней).

Страница chrome://topics-internals с выбранной панелью «Функции и параметры».
На панели «Функции и параметры» chrome://topics-internals отображаются включенные функции, время на эпоху, количество эпох, используемых для расчета тем, версия таксономии и другие настройки.

Показанные на скриншоте параметры соответствуют флагам, которые можно установить при запуске Chrome из командной строки. Например, демо-версия на темы-fetch-demo.glitch.me рекомендует использовать следующие флаги:

--enable-features=BrowsingTopics,BrowsingTopicsParameters:time_period_per_epoch/15s/max_epoch_introduction_delay/3s,PrivacySandboxAdsAPIsOverride,PrivacySandboxSettings3,OverridePrivacySandboxSettingsLocalTesting

В следующем списке поясняется каждый параметр, его значение по умолчанию и его назначение.

Флаги Chrome

BrowsingTopics
Значение по умолчанию: включено
Включен ли API тем.

PrivacySandboxAdsAPIsOverride
Значение по умолчанию: включено
Включает рекламные API: отчеты об атрибуции, защищенная аудитория, темы, изолированные фреймы.

PrivacySandboxSettings4
Значение по умолчанию: отключено
Включает четвертый выпуск настроек пользовательского интерфейса Privacy Sandbox.

OverridePrivacySandboxSettingsLocalTesting
Значение по умолчанию: включено
Если этот параметр включен, браузер больше не требует включения базовых настроек для включения функций Privacy Sandbox.

BrowsingTopicsBypassIPIsPubliclyRoutableCheck
Значение по умолчанию: отключено
Если этот параметр включен, проверка того, является ли IP-адрес общедоступным, будет пропущена при определении возможности включения страницы в расчет тем.

BrowsingTopics:number_of_epochs_to_expose
Значение по умолчанию: 3
Количество эпох, на основе которых можно рассчитать темы для передачи запрашивающему контексту. Браузер внутренне поддерживает до N+1 эпох.

BrowsingTopics:time_period_per_epoch
Значение по умолчанию: 7д-0ч-0м-0с.
Продолжительность каждой эпохи. Для отладки может быть полезно установить это значение, скажем, на 15 секунд, а не на семь дней по умолчанию.

BrowsingTopics:number_of_top_topics_per_epoch
Значение по умолчанию: 5
Количество тем рассчитывается за эпоху.

BrowsingTopics:use_random_topic_probability_percent
Значение по умолчанию: 5
Вероятность того, что отдельная тема в эпоху случайно получена из всей таксономии тем. Случайность привязана к эпохе и месту.

BrowsingTopics:number_of_epochs_of_observation_data_to_use_for_filtering
Значение по умолчанию: 3
Сколько эпох данных об использовании API (т. е. наблюдений за темами) будут использоваться для фильтрации тем для контекста вызова.

BrowsingTopics:max_number_of_api_usage_context_domains_to_keep_per_topic
Значение по умолчанию: 1000
Максимальное количество наблюдаемых контекстных доменов, которое можно сохранить для каждой основной темы. Целью является ограничение используемой памяти.

BrowsingTopics:max_number_of_api_usage_context_entries_to_load_per_epoch
Значение по умолчанию: 100000
Максимальное количество записей, которые можно получить из базы данных для каждого запроса для контекстов использования API. Запрос будет выполняться один раз в эпоху во время расчета тем. Цель состоит в том, чтобы ограничить пиковое использование памяти.

BrowsingTopics:max_number_of_api_usage_context_domains_to_store_per_page_load
Значение по умолчанию: 30
Максимальное количество доменов контекста использования API, которое разрешено хранить на одну загрузку страницы.

BrowsingTopics:config_version
Значение по умолчанию: 1
Кодирует параметры конфигурации API тем. Каждый номер версии должен быть сопоставлен только с одним набором конфигурации. Обновление параметров конфигурации без обновления config_version обычно подходит для локального тестирования, но в некоторых ситуациях может оставить браузер в несогласованном состоянии и привести к сбою браузера, например, обновление number_of_top_topics_per_epoch .

BrowsingTopics:taxonomy_version
Значение по умолчанию: 1
Версия таксономии , используемая API.

Отказаться от вашего сайта

Вы можете отказаться от расчета тем для определенных страниц вашего сайта, включив на странице заголовок Permissions-Policy: browsing-topics=() Permissions-Policy , чтобы предотвратить расчет тем только для всех пользователей на этой странице. Последующие посещения других страниц вашего сайта это не повлияет: если вы установите политику блокировки Topics API на одной странице, это не повлияет на другие страницы.

Вы также можете контролировать, какие третьи лица имеют доступ к темам на вашей странице, используя заголовок Permissions-Policy для управления доступом третьих лиц к API тем. В качестве параметров заголовка используйте self и любые домены, которым вы хотите разрешить доступ к API. Например, чтобы полностью отключить использование API тем во всех контекстах просмотра, кроме вашего собственного источника и https://example.com , установите следующий заголовок ответа HTTP:

Permissions-Policy: browsing-topics=(self "https://example.com")

Следующие шаги

Узнать больше

Привлекайте и делитесь отзывами