Non consigliamo più l'API App Events per le nuove integrazioni. L'API Conversions ora supporta gli eventi web, nell'app e offline, pertanto consigliamo agli inserzionisti di usare l'API Conversions invece dell'API App Events. Gli utenti esistenti dell'API App Events possono continuare a usarla, ma lo sviluppo verrà interrotto. Le innovazioni future saranno sviluppate sull'API Conversions. Scopri di più sull'API Conversions per App Events.
App Events ti consente di monitorare le azioni che si verificano nella tua app mobile o sulla pagina web, come installazioni dell'app ed eventi di acquisto. Monitorando questi eventi puoi misurare le prestazioni delle inserzioni e creare un pubblico per la targetizzazione delle inserzioni.
Per informazioni sul monitoraggio degli eventi nell'app per la messaggistica aziendale, fai riferimento all'API App Events per la messaggistica aziendale nella nostra documentazione sulla Piattaforma Messenger.
Esistono tre tipi di eventi nell'app:
Un evento nell'app è composto da tre parti:
name
: una stringa obbligatoria che descrive l'evento. Il nome viene visualizzato nel registro eventi quando l'evento nell'app viene inviato ad Analytics.valueToSum
: un valore opzionale che Analytics aggiunge ad altri parametri di Value To Sum correlati agli eventi nell'app con lo stesso nome.parameters
: valori opzionali compresi con l'evento nell'app.È possibile attribuire massimo 1000 nomi diversi agli eventi. Nota: una volta raggiunto questo limite, non vengono registrati nuovi tipi di evento. Se lo superi, potresti visualizzare l'errore 100 Invalid parameter
al momento della registrazione. Tuttavia, è possibile disattivare eventi obsoleti. Per scoprire di più sui limiti degli eventi, consulta la sezione FAQ.
Ecco cosa ti servirà:
Invia una richiesta POST
dal tuo server all'endpoint /{app-id}/activities
con i parametri application_tracking_enabled
e advertiser_tracking_enabled
:
curl -i -X POST "https://graph.facebook.com/{app-id}/activities ?event=MOBILE_APP_INSTALL &application_tracking_enabled=0 &advertiser_tracking_enabled=0 &advertiser_id={advertiser-tracking-id} &{app-access-token}"
In caso di azione eseguita correttamente, l'app riceve la seguente risposta:
{ "success": true }
Consulta la nostra Guida di riferimento per le attività dell'app per una lista dei parametri disponibili.
Il campo advertiser_tracking_enabled
specifica se una persona ha abilitato sul dispositivo il monitoraggio delle inserzioni. Il parametro è 0 per monitoraggio disabilitato o 1 per monitoraggio abilitato. Devi recuperare questi dati e restituirli a Facebook per determinare se il monitoraggio delle inserzioni può essere utilizzato per l'ottimizzazione o le conversioni. Meta utilizzerà i dati relativi agli eventi (raccolti dai partner sulle attività utente fuori da Meta) in accordo con la sua Normativa sui dati, dunque anche per i report pubblicitari, il rilevamento frodi e la creazione e il miglioramento dei prodotti (compresi i prodotti per la pubblicazione delle inserzioni), ma limiterà l'uso dei dati di quell'utente alla personalizzazione delle sue inserzioni. Per i dispositivi che eseguono versioni precedenti a iOS 6, questo parametro deve essere per impostazione predefinita su 1.
Consulta il riferimento Apple per AdSupport per ottenere lo stato del monitoraggio di un utente.
Lo snippet di codice seguente illustra come recuperare il valore del contrassegno "Monitoraggio abilitato".
Puoi ottenere l'impostazione attuale del contrassegno "Monitoraggio abilitato" dalla proprietà Settings.shared.isAdvertiserTrackingEnabled
.
print("isAdvertiserTrackingEnabled: \(Settings.shared.isAdvertiserTrackingEnabled)")
Qualsiasi app può contenere un'impostazione che consenta agli utenti di disattivare il monitoraggio delle inserzioni al suo interno. Facebook chiede ai partner di includere questa opzione nel loro SDK e riportare la scelta dell'utente a Facebook unitamente all'evento di installazione o conversione. Facebook usa l'evento di installazione o di conversione per i report pubblicitari, ma consente di usarlo nell'ottimizzazione delle inserzioni in modo limitato. L'impostazione scelta dell'utente deve restare invariata a ogni avvio dell'app.
Invia una richiesta POST
all'endpoint /{app-id}/activities
con l'elemento event
impostato su CUSTOM_APP_EVENTS
e imposta advertiser_tracking_enabled
per ogni singolo evento. Uno tra i parametri advertiser_id
e attribution
è obbligatorio.
curl -i -X POST "https://graph.facebook.com/{app-id}/activities ?event=CUSTOM_APP_EVENTS" &advertiser_id={advertiser-tracking-id} &advertiser_tracking_enabled=1 &application_tracking_enabled=1 &custom_events=[ {"_eventName":"fb_mobile_purchase", "event_id":"123456", "fb_content":"[ {"id": "1234", "quantity": 2,}, {"id": "5678", "quantity": 1,} ]", "fb_content_type":"product", "_valueToSum":21.97, "fb_currency":"GBP", } ] &{app-access-token}"
In caso di azione eseguita correttamente, l'app riceve la seguente risposta:
{ "success": true }
L'endpoint attribution
restituisce gli eventi di installazione e conversione in base ai clic su un'inserzione in un periodo di tempo di 28 giorni. Gestione inserzioni utilizza un modello di attribuzione da 1 giorno dalla visualizzazione a 28 giorni dal clic e gli insight vengono visualizzati in base al momento dell'impression o del clic, non a quello di installazione o conversione. Questo aspetto è importante quando confronti i tuoi report con quelli di Gestione inserzioni di Facebook. Oltre alle richieste standard di eventi nell'app relative ai clic sull'inserzione, devi tenere a mente anche i seguenti scenari:
Richieste di attribuzione di visualizzazioni: l'impostazione consider_views=TRUE
restituisce i dati di attribuzione per gli eventi di installazione avvenuti entro 1 giorno dall'impression dell'inserzione, a condizione che l'account del Centro gestione account non abbia cliccato su un'inserzione in un periodo di 28 giorni. La risposta restituita sarà is_view_through=TRUE
e view_time
sostituirà click_time
. Tutte le altre attribuzioni sono uguali a quelle dei dati di attribuzione per clic sulle inserzioni.
Richieste inter-campagna: gli inserzionisti possono monitorare le prestazioni di tutte le inserzioni che hanno portato a un evento nell'app. Facebook invia richieste per eventi da campagne pubblicitarie purché l'obiettivo della campagna non sia impostato sull'installazione di app mobili o sull'interazione con tali app. Questi dati vengono visualizzati solo se l'inserzionista ha aggiunto l'app al campo "Mobile App Events Tracking" nell'inserzione.
Caso d'uso: se il cliente desidera monitorare gli eventi di installazione generati dall'inserzione che rimanda a un post della Pagina o invita a cliccare su un sito web che reindirizza gli utenti a un sito per dispositivi mobili, può farlo in Gestione inserzioni: Facebook richiederà gli eventi di installazione dell'app rilevanti.
Richieste cross-device: gli inserzionisti con app multipiattaforma ora possono vedere le installazioni dell'app generate dalle inserzioni sulle varie piattaforme.
Caso d'uso: un utente clicca su un'inserzione di un'app per iPhone e poi la installa sul proprio iPad. Ciò consente di attribuire l'installazione dell'app per iPad all'inserzione per iPhone indipendentemente dalla targetizzazione dell'inserzione.
L'associazione avanzata ti consente di inviare i dati dei clienti a Facebook, che il utilizzerà per determinare in modo più accurato quali account del Centro gestione account hanno intrapreso un'azione in risposta alla tua inserzione. Con questi dati, Facebook può abbinare gli eventi di conversione ai tuoi clienti per ottimizzare le tue inserzioni e creare gruppi di pubblico di remarketing più ampi.
Invia una richiesta POST
all'endpoint /{app-id}/activities
con il parametro ud
impostato in modo che consenta di monitorare i dati dei cliente, come l'e-mail o il numero di telefono. Tutti i dati dei clienti devono essere sottoposti ad algoritmo di hashing; in caso contrario, Facebook li ignorerà. Assicurati di impostare advertiser_tracking_enabled
per ogni singolo evento.
curl -i -X POST "https://graph.facebook.com/{app-id}/activities ?event=CUSTOM_APP_EVENTS &advertiser_id={advertiser-tracking-id} &advertiser_tracking_enabled=1 &application_tracking_enabled=1 &custom_events=[ {"_eventName":"fb_mobile_purchase", "event_id":"123456", "fb_content":"[ {"id": "1234", "quantity": 2,}, {"id": "5678", "quantity": 1,} ]", "fb_content_type":"product", "_valueToSum":21.97, "fb_currency":"GBP", } ] &ud[em]={sha256-hashed-email} &{app-access-token}"
In caso di azione eseguita correttamente, l'app riceve la seguente risposta:
{ "success": true }
Tutti i dati utente devono essere in formato hash con algoritmo SHA256 prima di essere inviati a Facebook. In caso contrario, Facebook li ignorerà.
Per gli eventi nell'app, applichiamo la stessa funzionalità di deduplicazione esistente per gli eventi web. La logica utilizza la deduplicazione basata sui campi event_id
e event_name
. Il parametro event_id
è un identificativo in grado di distinguere in modo univoco gli eventi simili. ID evento inaccurati possono causare una deduplicazione errata della conversione, con conseguente impatto sul report sulle conversioni e sulle prestazioni della campagna.
Puoi inviare informazioni sul dispositivo, come larghezza e altezza dello schermo, nella chiamata all'evento nell'app usando /{app-id}/activities?extinfo
. I valori sono separati da virgole e devono essere nell'ordine indicizzato nella guida di riferimento /application/activites
. Quando utilizzi extinfo
, tutti i valori sono obbligatori.
version
deve essere a2
per Android version
deve essere i2
per iOSTi consigliamo di associare gli eventi nell'app a un advertiser_id
. Per i dispositivi Android e i dispositivi iOS precedenti a iOS 6, puoi anche usare il parametro attribution
impostato sui cookie per dispositivi mobili del dispositivo.
Nota: i cookie per dispositivi mobili non derivano da alcun attributo utente o dispositivo. Non sono permanenti e sono progettati per essere aggiornati di frequente. Non usare i cookie per dispositivi mobili per il retargeting delle inserzioni.
Un cookie è una stringa alfanumerica di 22 caratteri casuali.
Acquisisci l'ID attribuzione Facebook usando ContentProvider
:
public static final Uri ATTRIBUTION_ID_CONTENT_URI = Uri.parse("content://com.facebook.katana.provider.AttributionIdProvider"); public static final String ATTRIBUTION_ID_COLUMN_NAME = "aid"; public static String getAttributionId(ContentResolver contentResolver) { String [] projection = {ATTRIBUTION_ID_COLUMN_NAME}; Cursor c = contentResolver.query(ATTRIBUTION_ID_CONTENT_URI, projection, null, null, null); if (c == null || !c.moveToFirst()) { return null; } String attributionId = c.getString(c.getColumnIndex(ATTRIBUTION_ID_COLUMN_NAME)); c.close(); return attributionId; }
Devi inoltre recuperare l'ID pubblicitario dell'app Android.
I cookie per dispositivi mobili sono creati dalle app Facebook per iOS tramite l'elemento CFUUIDCreateString
e si tratta di una rappresentazione di stringa UUID a 128 bit.
Ottieni sia l'ID cookie sia l'IDFA e inviali a Facebook come identificativo:
ASIdentifierManager *manager = [ASIdentifierManager sharedManager]; NSString *advertiserID = [[manager advertisingIdentifier] UUIDString]; if (advertiserID) { // do stuff }
Se le richieste POST
vengono effettuate da un luogo centrale come un server o proxy, fondamentalmente una chiamata da server a server, l'header HTTP X-Forwarded-For è obbligatorio per garantire che le informazioni su posizione e dispositivo siano accurate. Invia l'indirizzo IP del dispositivo, in formato IPv4 o IPv6, tramite il parametro dell'intestazione HTTP X-Forwarded-For in ognuna delle richieste di eventi nell'app inviate. Ciò consente di associare l'advertiser_id
all'indirizzo IP corretto, che può quindi essere utilizzato nella nostra piattaforma.
curl ... -H "X-Forwarded-For: fd45:f238:3b40:23b1:ffff:ffff:ffff:abcd" \ https://graph.facebook.com/<APP_ID>/activities/
curl ... -H "X-Forwarded-For: 192.168.0.99" \ https://graph.facebook.com/<APP_ID>/activities
Se un cliente confronta i report di un Mobile Measurement Partner con quelli di Facebook e nota discrepanze, occorre verificare gli elementi seguenti:
Se Facebook riporta un numero minore di installazioni rispetto all'MMP:
Se Facebook riporta un numero maggiore di installazioni rispetto all'MMP:
Per maggiori informazioni sulle informazioni estese sull'app, consulta la guida di riferimento /application/activites
.
per gli esempi di dati correttamente normalizzati e in formato hash per i seguenti parametri.
Dati | Parametro | Esempio | Linee guida per il formato |
---|---|---|---|
Città |
| menlopark | Città in minuscolo con gli spazi rimossi |
Paese |
| US | Prefisso internazionale di due lettere in ISO 3166-1 alpha-2 |
Data di nascita |
| 19911226 | Giorno, mese e anno di nascita, come |
| jsmith@example.com | Indirizzo e-mail della persona in minuscolo | |
Nome |
| john | Nome in minuscolo |
Genere |
| m |
|
Cognome |
| smith | Cognome in minuscolo |
Telefono |
| 16505551212 | Numero di telefono, solo cifre contenenti il prefisso internazionale, il prefisso e il numero |
Provincia/stato |
| ca | Codice stato/provincia di due lettere |
CAP |
| 94035 | CAP di cinque cifre |
Event Name | Event Parameters | _valueToSum |
---|---|---|
|
| |
|
| With App Ads, revenue of ads from a third-party platform appears on-screen within your app. |
| ||
| ||
| ||
|
| |
| ||
|
| |
|
| Price of item added |
|
| Price of item added |
|
| |
|
| Price of item viewed (if applicable) |
|
| Total price of items in cart |
|
| |
|
| Purchase price |
|
| Rating given |
|
| |
|
| Total value of credits spent |
|
| |
| ||
| ||
|
| Price of subscription |
| ||
|
| Price of subscription |
*Use fb_mobile_activate_app
event in addition to install reporting to exclude users from seeing ads for this app. Do not use this event if you have automatic event logging enabled.
Nome parametro dell'evento | Valore | Descrizione |
---|---|---|
| int | Parametro consigliato per specificare l'ora dell'evento, in formato UNIX. |
| float | Valore numerico di un singolo evento da aggiungere al report, vedi sopra per gli eventi consigliati da collegare. |
| stringa | Numero EAN (codice identificativo articolo internazionale), se applicabile, o altri identificativi del prodotto o contenuto. Per più ID prodotto, ad es., "[\"1234\",\"5678\"]". |
| stringa | Una lista di oggetti JSON che contiene il numero EAN (codice identificativo articolo internazionale), se applicabile, o altri identificativi del prodotto o contenuto, nonché quantità e prezzi dei prodotti. Obbligatorio: |
| stringa |
|
| stringa | Codice ISO 4217, ad es., "EUR", "USD", "JPY". Obbligatorio se trasmetti |
| stringa | Una descrizione della stringa. |
| stringa | Livello di un gioco. |
| int | I limiti superiori di una scala di valutazione, ad esempio 5 su una scala a 5 stelle. |
| int | Numero di articoli. |
| booleano |
|
| stringa | Facebook, e-mail, Twitter ecc. |
| stringa | La stringa di testo che è stata cercata. |
| booleano |
|