İç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.
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.
(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();
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.
- GitHub: Teklifi okuyun, soruları sorun ve tartışmaya katılın.
- Shared Storage API duyuruları: Posta listemizdeki eski duyurulara katılın veya bu duyuruları görüntüleyin
- Geliştirici desteği: Özel Korumalı Alan Geliştirici Desteği deposunda soru sorun ve tartışmalara katılın.