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.
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();
// 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.
- Teklif: Ayrıntılı teklifi inceleyin.
- Tartışma: Soru sormak ve görüşlerinizi paylaşmak için devam eden tartışmaya katılın.