Kullanıcı demografilerini ölçme

İçerik üreticileri genellikle kitlelerinin demografisini anlamak isterler. Paylaşılan Depolama'yı kullanarak kullanıcı demografik verilerini sahip olduğunuz bir bağlamda (ör. birinci taraf siteniz) kaydedebilir ve daha sonra bu verileri diğer sitelerden (ör. yerleştirilmiş içeriğiniz) alınan raporlara dahil etmek için toplu raporlardan yararlanabilirsiniz.

Shared Storage API, pek çok olası kullanım alanını destekleyen genel amaçlı ve siteler arası depolamaya yönelik bir Özel Korumalı Alan teklifidir. Private Aggregation API, siteler arası verileri birleştirmenize olanak tanıyan, paylaşılan depolama alanında bulunan bir çıkıştır.

Kullanıcı demografik ölçümünü deneyin

Paylaşılan Depolama Alanı ve Gizli Toplama ile kullanıcı demografisi ölçümüyle denemeler yapmak için Chrome Canary ve M107 veya sonraki bir sürümü kullandığınızı onaylayın. Ardından chrome://flags/#privacy-sandbox-ads-apis adresinde Özel Korumalı Alan Reklamları API'leri denemesi işaretini etkinleştirin.

Bu API'leri kullanmak için Özel Korumalı Alan Reklamları API'leri denemesini etkin olarak ayarlayın.

Paylaşılan Depolama'yı komut satırındaki --enable-features=PrivacySandboxAdsAPIsOverride,OverridePrivacySandboxSettingsLocalTesting,SharedStorageAPI,FencedFrames işaretiyle de etkinleştirebilirsiniz.

Kod örnekleriyle deneme yapma

Örneğin, yaş aralığı veya coğrafi konum gibi, içeriğinizi farklı sitelerde gören kullanıcıların belirli demografik özelliklerini ölçmek isteyebilirsiniz. Bu örnekte içerik kimliği, yaş grubu kimliği ve coğrafi konum kimliği boyutları, toplama anahtarına (paket) kodlanmıştır ve sayı, birleştirilebilir değer olarak kullanılmıştır. Oluşturulan özet raporda, "123 Content ID'yi gören ve 18-39 yaşları arasında Avrupa'da yaşayan yaklaşık 391 kullanıcı" gibi bilgiler sağlar.

Bu örnekte:

  • demographic-measurement.js bir çerçeve üzerinden yüklendi ve paylaşılan depolama iş yükünün yüklenmesinden sorumlu.
  • demographic-measurement-worklet.js, paylaşılan depolama alanındaki demografi verilerini okuyan ve Private Aggregation API aracılığıyla bir rapor gönderen paylaşımlı depolama iş uygulamasıdır.

store-demographic-data.js

(Demografi verilerini Paylaşılan Depolama Alanı'nda ayarlamak için ölçüm yapılmadan önce belirli bir zamanda çalışır)

function getDemogrationsData() {
  // Collect age group and continent data
  return {
    ageGroup,
    continent
  }
}

async function storeDemographics() {
  const { ageGroup, continent } = getDemographicsData();
  await window.sharedStorage.set('age-group', ageGroup);
  await window.sharedStorage.set('continent', continent);
}

storeDemographics();

demographic-measurement.js

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

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

measureDemographics();

demographic-measurement-worklet.js

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

/**
 * The bucket key must be a number, and in this case, it is simply the ad campaign
 * ID itself. For more complex bucket key construction, see other use cases in
 * this demo.
 */

const AGGREGATION_KEY_MAP = {
  ageGroupId: {
    '18-39': '1',
    '40-64': '2',
    '65+': '3',
  },

  continentId: {
    africa: '1',
    antarctica: '2',
    asia: '3',
    australia: '4',
    europe: '5',
    'north-america': '6',
    'south-america': '7',
  },

};

/**
 * The aggregation key will be in the format of:
 * contentId | ageGroupId | continentId
 *
 * For example, a user from Australia between the age of 40-64, who has
 * seen the Content ID 321 will be represented by the key:
 * 321 | 2 | 4 or 32124
 */

function generateAggregationKey(contentId, ageGroup, continent) {
  const ageGroupId = AGGREGATION_KEY_MAP.ageGroupId[ageGroup];
  const continentId = AGGREGATION_KEY_MAP.continentId[continent];
  const aggregationKey = BigInt(`${contentId}${ageGroupId}${continentId}`);

  return aggregationKey;
}

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

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

    // Do not report if a report has been sent already
    if (hasReportedContent) {
      return;
    }

    // Generate the aggregation key and the aggregatable value
    const bucket = generateAggregationKey(contentId, ageGroup, continent);
    const value = 1 * SCALE_FACTOR;

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

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

// Register the operation
register('demographics-measurement', DemographicsMeasurementOperation); \

Etkileşimde bulunun ve geri bildirim paylaşın

Paylaşılan Depolama alanı teklifi şu anda etkin bir şekilde tartışılmaktadır ve gelecekte değiştirilebilir. Bu API'yi deneyip geri bildirimde bulunursanız memnuniyet duyarız.