Personalizza i report sugli arresti anomali di Firebase Crashlytics


Nella dashboard di Crashlytics, puoi fare clic su un problema e visualizzare report sugli eventi. Puoi personalizzare questi report per comprendere meglio cosa succede nella tua app e le circostanze relative agli eventi segnalati a Crashlytics.

  • Ricevi automaticamente i log breadcrumb se la tua app utilizza la SDK Firebase per Google Analytics. Questi log ti offrono visibilità Azioni utente che hanno portato a un evento raccolto da Crashlytics nella tua app.

  • Disattivare i report automatici sugli arresti anomali e abilitare i report di attivazione per i tuoi utenti. Tieni presente che, per per impostazione predefinita, Crashlytics raccoglie automaticamente i report sugli arresti anomali per tutti i tuoi utenti dell'app.

Segnalare eccezioni

Segnala eccezioni rilevate

Se sono previste eccezioni previste, puoi avere l'SDK Crashlytics e segnalali come eventi non irreversibili. Questi eventi vengono registrati sul dispositivo poi inviato insieme al successivo report sugli eventi irreversibili o al riavvio dell'utente finale. al gioco.

Puoi registrare le eccezioni in C# utilizzando il seguente metodo:

Crashlytics.LogException(Exception ex);

Puoi registrare le eccezioni previste nei blocchi try/catch del gioco:

try {
    myMethodThatThrows();
} catch (Exception e) {
   Crashlytics.LogException(e);
   // handle your exception here!
}

Segnala eccezioni non rilevate

Per le eccezioni non rilevate che non causano l'arresto anomalo del gioco (ad esempio, non rilevate). C# nella logica di gioco), puoi fare in modo che l'SDK Crashlytics le segnali come eventi irreversibili impostando il valore proprietà Crashlytics.ReportUncaughtExceptionsAsFatal in true, dove inizializza Crashlytics nel tuo progetto Unity di Google. Questi eventi vengono segnalati a Crashlytics in tempo reale senza bisogno di all'utente finale per riavviare il gioco.

Segnalare queste eccezioni non rilevate come eventi irreversibili significa che verranno conteggiate le statistiche sugli utenti senza arresti anomali e gli avvisi di velocità.

Tieni presente che gli arresti anomali nativi vengono sempre segnalati come eventi irreversibili. Questi vengono registrati sul dispositivo e inviati quando l'utente finale riavvia per giocare.

void Start() {
    // Since there is no try-block surrounding this call, if an exception is thrown,
    // it is considered unexpected.
    // Setting `Crashlytics.ReportUncaughtExceptionsAsFatal = true`
    // will ensure that such cases are reported as fatals.
    thirdPartyMethodThatMayThrow();
}

Includi i report GWP-ASan per eseguire il debug dei problemi di danneggiamento della memoria

Per le app per Android che utilizzano IL2CPP, Crashlytics può aiutarti a eseguire il debug degli arresti anomali causati da errori di memoria nativi tramite la raccolta di report GWP-ASan. Questi gli errori relativi alla memoria possono essere associati a un danneggiamento della memoria dell'app che è la principale causa di vulnerabilità di sicurezza delle app.

  • Puoi visualizzare questi dati in una nuova scheda "Tracce dello stack della memoria" quando fai clic sui dettagli di un problema nella dashboard Crashlytics.

  • Puoi anche utilizzare il nuovo indicatore e filtro "Report GWP-ASan" per visualizzare rapidamente tutti i problemi relativi a questi dati.

Puoi ricevere report sulla memoria GWP-ASan se la tua app utilizza l'SDK Crashlytics più recente per Unity (v10.7.0 o versioni successive) e ha GWP-ASan esplicitamente abilitato (è necessario modificare il file manifest dell'app per Android). Se nella tua app è presente codice C++, puoi testare la configurazione GWP-ASan utilizzando il di codice nativo di esempio nella documentazione di Android.

Aggiungi chiavi personalizzate

Le chiavi personalizzate ti consentono di conoscere lo stato specifico della tua app che ha causato un arresto anomalo. Puoi associare coppie chiave/valore arbitrarie ai report sugli arresti anomali, quindi utilizzare le chiavi personalizzate per cercare e filtrare i report sugli arresti anomali nella console Firebase.

  • Nella dashboard di Crashlytics, puoi cercare i problemi. che corrispondono a una chiave personalizzata.
  • Quando esamini un problema specifico nella console, puoi visualizzare le chiavi personalizzate associate per ogni evento (scheda secondaria Chiavi) e persino filtrare gli eventi in base alle chiavi personalizzate (menu Filtro nella parte superiore della pagina).
di Gemini Advanced.

Se viene chiamato più volte, i nuovi valori per le chiavi esistenti aggiorneranno il valore e solo il valore più recente viene acquisito quando viene registrato un arresto anomalo.

Crashlytics.SetCustomKey(string key, string value);

Aggiungere messaggi di log personalizzati

I messaggi registrati sono associati ai dati degli arresti anomali e sono visibili nel dashboard Firebase Crashlytics durante la visualizzazione di un arresto anomalo specifico.

Crashlytics.Log(string message);

Impostare gli identificatori degli utenti

Puoi utilizzare un numero ID, un token o un valore hash per identificare in modo univoco il l'utente finale della tua applicazione senza divulgare o trasmettere la propria informazioni personali. Puoi anche cancellare il valore impostandolo su un valore vuoto stringa. Questo valore viene visualizzato nella dashboard Firebase Crashlytics quando la visualizzazione di un arresto anomalo specifico.

Crashlytics.SetUserId(string identifier);

Recupera log dei breadcrumb

I log dei breadcrumb ti consentono di comprendere meglio le interazioni di un utente con la tua app che hanno portato a un arresto anomalo, a un evento non irreversibile o ANR. Questi log possono essere utile quando si cerca di riprodurre un problema ed eseguirne il debug.

I log dei breadcrumb sono basati su Google Analytics, quindi per ottenere i log dei breadcrumb, necessario abilita Google Analytics per il tuo progetto Firebase aggiungi l'SDK Firebase per Google Analytics alla tua app. Una volta soddisfatti questi requisiti, i log dei breadcrumb vengono automaticamente inclusione dei dati di un evento nella scheda Log quando visualizzi i dettagli di un problema.

L'SDK Analytics registra automaticamente l'evento screen_view che consente ai log dei breadcrumb di mostrare un elenco delle schermate visualizzate prima del di un evento di arresto anomalo, non irreversibile o ANR. Un log breadcrumb screen_view contiene un firebase_screen_class.

I log dei breadcrumb vengono anche compilati con qualsiasi eventi personalizzati che registri manualmente nell'account dell'utente. sessione, inclusi i dati dei parametri dell'evento. Questi dati possono aiutare a mostrare una serie di azioni utente che hanno portato a un evento di arresto anomalo, non irreversibile o ANR.

Tieni presente che puoi controllare la raccolta e l'utilizzo dei dati Google Analytics, che includono i dati che compilano i log dei breadcrumb.

Attiva i report di attivazione

Per impostazione predefinita, Crashlytics raccoglie automaticamente i report sugli arresti anomali relativi a tutti i tuoi utenti dell'app. Per dare agli utenti un maggiore controllo sui dati inviati, attivare la segnalazione degli arresti anomali.

Per disattivare la raccolta automatica e inizializzare Crashlytics solo per gli elementi selezionati agli utenti, chiama l'override della raccolta dati di Crashlytics in fase di runtime. Il valore di override persiste nei vari lanci dell'app, in modo che Crashlytics possa raccogliere automaticamente i report. Per disattivare i report automatici sugli arresti anomali, passa false come valore di override. Se impostato su false, il nuovo valore non fino alla successiva esecuzione dell'app.

Crashlytics.IsCrashlyticsCollectionEnabled = true

Gestisci i dati di Crash Insights

Crash Insights ti aiuta a risolvere i problemi confrontando il tuo stack anonimo da altre app Firebase e ti comunica se il problema è parte di una tendenza più ampia. Per molti problemi, Crash Insights fornisce anche per eseguire il debug dell'arresto anomalo.

Crash Insights utilizza dati aggregati sugli arresti anomali per identificare tendenze comuni di stabilità. Se preferisci non condividere i dati della tua app, puoi disattivare Crash Insights dal menu Approfondimenti sugli arresti anomali nella parte superiore dell'elenco dei problemi Crashlytics nella console Firebase.