Tekil erişim ölçümü

Birçok içerik üretici ve reklamveren, içeriklerini kaç tekil kullanıcının gördüğünü bilmek ister. Bir kullanıcının reklamınızı, yerleştirilmiş videonuzu veya yayınınızı ilk kez gördüğü zamanı kaydetmek ve aynı kullanıcının farklı sitelerde tekrar tekrar sayılmasını önlemek için Shared Storage'ı kullanın. Ardından, erişiminizle ilgili bir özet rapor oluşturmak için Private Aggregation API'yi kullanabilirsiniz.

Shared Storage API, genel amaçlı, siteler arası depolama için bir Özel Korumalı Alan önerisidir ve birçok olası kullanım alanını destekler. Private Aggregation API, siteler arası verileri toplamanıza olanak tanıyan ve Shared Storage'da kullanılabilen bir çıktıdır. Bu ölçümleri uygulama yöntemleri hakkında daha fazla bilgi edinmek için erişim teknik belgemize göz atın.

Tekil erişim ölçümünü deneyin

Shared Storage ve Private Aggregation ile benzersiz erişim ölçümü denemesi yapmak için Chrome M107 veya sonraki bir sürümünü kullandığınızı doğrulayın. chrome://settings/adPrivacy bölümündeki tüm reklam gizliliği API'lerini etkinleştirin.

Paylaşılan Depolama Alanı'nı komut satırındaki --enable-features=PrivacySandboxAdsAPIsOverride,OverridePrivacySandboxSettingsLocalTesting,SharedStorageAPI,FencedFrames işaretini kullanarak da etkinleştirebilirsiniz.

Kod örnekleriyle denemeler yapma

İçeriğinizi farklı sitelerde kaç benzersiz kullanıcının gördüğünü takip etmek isteyebilirsiniz. Bu örnekte, içerik kimliği boyutu toplama anahtarına (paket) kodlanır ve sayı, toplanabilir değer olarak kullanılır. Özet raporunda "Yaklaşık 391 kullanıcı, 123 numaralı içerik kimliğini gördü." gibi bilgiler yer alır.

Bu örnekte:

  • unique-reach-measurement.js, bir çerçeve kullanılarak yüklenir ve paylaşılan depolama alanı işlevini yüklemekten sorumludur.
  • unique-reach-measurement-worklet.js, ortak depolamadaki işareti kontrol eden ve Private Aggregation API'yi kullanarak rapor gönderen ortak depolama işlevidir.

reach-measurement.js

async function measureUniqueReach() {
  // Load the Shared Storage worklet
  await window.sharedStorage.worklet.addModule('reach-measurement-worklet.js');

  // Run the reach measurement operation
  await window.sharedStorage.run('reach-measurement', { data: { contentId: '1234' } });
}

measureUniqueReach();

reach-measurement-worklet.js

// Learn more about noise and scaling from the Private Aggregation fundamentals
// documentation on Chrome blog
const SCALE_FACTOR = 65536;

function convertContentIdToBucket(contentId) {
  return BigInt(contentId);
}

class ReachMeasurementOperation {
  async run(data) {
    const { contentId } = data;

    // Read from Shared Storage
    const key = 'has-reported-content';
    const hasReportedContent = (await sharedStorage.get(key)) === 'true';

    // Don't report if a report has been sent already
    if (hasReportedContent) {
      return;
    }

    // Generate the aggregation key and the aggregatable value
    const bucket = convertContentIdToBucket(contentId);
    const value = 1 * SCALE_FACTOR;

    // Send an aggregatable report using the Private Aggregation API
    privateAggregation.contributeToHistogram({ bucket, value });

    // Set the report submission status flag
    await sharedStorage.set(key, true);
  }
}

// Register the operation
register('reach-measurement', ReachMeasurementOperation);

Etkileşim kurma ve geri bildirim paylaşma

Shared Storage API teklifinin aktif olarak tartışılıp geliştirildiğini ve bu nedenle değişebileceğini unutmayın.

Shared Storage API hakkındaki düşüncelerinizi öğrenmek istiyoruz.