| Sélectionner la plate-forme : | iOS+ Android Flutter Unity |
Dans le tableau de bord Crashlytics, vous pouvez cliquer sur un problème pour obtenir un rapport d'événement détaillé. Vous pouvez personnaliser ces rapports pour mieux comprendre ce qui se passe dans votre application et les circonstances des événements signalés à Crashlytics.
Signalez les exceptions détectées et exceptions non détectées à Crashlytics.
Incluez des rapports GWP-ASan pour déboguer les problèmes de mémoire corrompue.
Instrumentez votre application pour enregistrer des clés personnalisées, messages de journal personnalisés, et des identifiants utilisateur.
Obtenez automatiquement des journaux de navigation si votre application utilise le SDK Firebase pour Google Analytics. Ces journaux vous donnent une visibilité sur les actions de l'utilisateur ayant conduit à un événement collecté par Crashlyticsdans votre application.
Désactivez le signalement automatique des plantages et activez le signalement sur activation pour vos utilisateurs. Notez que, par défaut, Crashlytics collecte automatiquement les rapports de plantage pour tous les utilisateurs de votre application.
Signaler des exceptions
Signaler les exceptions détectées
Si vous avez des exceptions attendues, vous pouvez demander au Crashlytics SDK de les signaler en tant qu'événements non fatals. Ces événements sont enregistrés sur l'appareil, puis envoyés avec le rapport d'événement fatal suivant ou lorsque l'utilisateur final redémarre le jeu.
Vous pouvez enregistrer des exceptions en C# à l'aide de la méthode suivante :
Crashlytics.LogException(Exception ex);
Vous pouvez enregistrer les exceptions attendues dans les blocs try/catch de votre jeu :
try { myMethodThatThrows(); } catch (Exception e) { Crashlytics.LogException(e); // handle your exception here! }
Signaler les exceptions non détectées
Pour les exceptions non détectées qui ne plantent pas votre jeu (par exemple, les exceptions C# non détectées dans la logique du jeu), vous pouvez demander au Crashlytics SDK de les signaler en tant qu'événements fatals en définissant la propriété Crashlytics.ReportUncaughtExceptionsAsFatal sur true lorsque vous initialisez Crashlytics dans votre projet Unity.
Ces événements sont signalés à Crashlytics en temps réel sans que
l'utilisateur final ait besoin de redémarrer le jeu.
Si vous signalez ces exceptions non détectées en tant qu'événements fatals, elles seront prises en compte dans vos statistiques d'utilisation sans plantage et dans les alertes de vitesse.
Notez que les plantages natifs sont toujours signalés en tant qu'événements fatals. Ces événements sont enregistrés sur l'appareil, puis envoyés lorsque l'utilisateur final redémarre le jeu.
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(); }
Inclure des rapports GWP-ASan pour déboguer les problèmes de mémoire corrompue
Pour les applications Android qui utilisent IL2CPP, Crashlytics peut vous aider à déboguer les plantages causés par des erreurs de mémoire native en collectant des rapports GWP-ASan. Ces erreurs liées à la mémoire peuvent être associées à une corruption de la mémoire dans votre application, qui est la principale cause des failles de sécurité des applications.
Vous pouvez afficher ces données dans un nouvel onglet "Traces de la pile de mémoire" lorsque vous cliquez sur les détails d'un problème dans le Crashlytics tableau de bord.
Vous pouvez également utiliser le nouveau signal et filtre "Rapport GWP-ASan" pour afficher rapidement tous les problèmes liés à ces données.
Vous pouvez obtenir des rapports de mémoire GWP-ASan si votre application utilise la dernière version du SDK Crashlytics pour Unity (v10.7.0 ou ultérieure) et si GWP-ASan est explicitement activé (vous devez modifier le fichier manifeste de votre application Android). Si votre application contient du code C++, vous pouvez tester votre configuration GWP-ASan à l'aide de l 'exemple de code natif de la documentation Android.
Ajouter des clés personnalisées
Les clés personnalisées vous permettent de connaître l'état spécifique de votre application pouvant entraîner un plantage. Vous pouvez associer des paires clé-valeur arbitraires à vos rapports de plantage, puis utiliser les clés personnalisées pour rechercher et filtrer les rapports de plantage dans la Firebase console.
- Dans le Crashlytics tableau de bord, vous pouvez rechercher les problèmes qui correspondent à une clé personnalisée.
- Lorsque vous examinez un problème spécifique dans la console, vous pouvez afficher les clés personnalisées associées à chaque événement (sous-onglet Clés) et même filtrer les événements par clés personnalisées (menu Filtrer en haut de la page).
Lorsqu'elles sont appelées plusieurs fois, les nouvelles valeurs des clés existantes mettent à jour la valeur, et seule la valeur la plus récente est capturée lorsqu'un plantage est enregistré.
Crashlytics.SetCustomKey(string key, string value);
Ajouter des messages de journal personnalisés
Les messages enregistrés sont associés à vos données de plantage et sont visibles dans le Firebase Crashlytics tableau de bord lorsque vous consultez un plantage spécifique.
Crashlytics.Log(string message);
Définir des identifiants utilisateur
Vous pouvez utiliser un numéro d'identification, un jeton ou une valeur hachée pour identifier de manière unique l'utilisateur final de votre application sans divulguer ni transmettre aucune de ses informations personnelles. Vous pouvez également effacer la valeur en la définissant sur une chaîne vide. Cette valeur s'affiche dans le tableau de bord Firebase Crashlytics lorsque vous consultez un plantage spécifique.
Crashlytics.SetUserId(string identifier);
Obtenir des journaux de navigation
Les journaux de navigation vous permettent de mieux comprendre les interactions d'un utilisateur avec votre application ayant conduit à un plantage, un problème non fatal ou un événement ANR. Ces journaux peuvent être utiles lorsque vous essayez de reproduire et de déboguer un problème.
Les journaux de navigation sont alimentés par Google Analytics. Pour les obtenir, vous devez activer Google Analytics pour votre projet Firebase et ajouter le SDK Firebase pour Google Analytics à votre application. Une fois ces conditions remplies, les journaux de navigation sont automatiquement inclus avec les données d'un événement dans l'onglet Journaux lorsque vous affichez les détails d'un problème.
Le Analytics SDK
enregistre automatiquement l'événement screen_view, ce qui permet aux journaux de navigation d'afficher une liste des écrans consultés avant le
plantage, le problème non fatal ou l'événement ANR. Un journal de navigation screen_view contient un paramètre firebase_screen_class.
Les journaux de navigation sont également remplis avec tous les événements personnalisés que vous enregistrez manuellement dans la session de l'utilisateur, y compris les données de paramètre de l'événement. Ces données peuvent montrer une série d'actions utilisateur ayant conduit à un plantage, un problème non fatal ou un événement ANR.
Notez que vous pouvez contrôler la collecte et l'utilisation des données Google Analytics, y compris les données qui remplissent les journaux de navigation.
Activer le reporting sur activation
Par défaut, Crashlytics collecte automatiquement les rapports de plantage pour tous les utilisateurs de votre application. Vous pouvez donner aux utilisateurs plus de contrôle sur les données qu'ils envoient en leur permettant d'activer le signalement des plantages.
Pour désactiver la collecte automatique uniquement pour certains utilisateurs, appelez le Crashlytics remplacement de la collecte de données au moment de l'exécution. La valeur de remplacement persiste lors de tous les lancements ultérieurs de votre application afin que Crashlytics puisse collecter automatiquement des rapports pour cet utilisateur.
Crashlytics.IsCrashlyticsCollectionEnabled = true
Si l'utilisateur désactive ultérieurement la collecte de données, vous pouvez transmettre false comme valeur de remplacement, qui s'appliquera lors du prochain lancement de l'application par l'utilisateur et persistera lors de tous les lancements ultérieurs pour cet utilisateur.
Gérer les données Crash Insights
Crash Insights vous aide à résoudre les problèmes en comparant vos traces de la pile anonymisées à celles d'autres applications Firebase et en vous indiquant si votre problème s'inscrit dans une tendance plus large. Pour de nombreux problèmes, Crash Insights fournit même des ressources pour vous aider à déboguer le plantage.
Crash Insights utilise des données de plantage agrégées pour identifier les tendances de stabilité courantes. Si vous préférez ne pas partager les données de votre application, vous pouvez désactiver Crash Insights dans le menu Crash Insights en haut de votre liste de problèmes Crashlytics dans la console Firebase.
Étapes suivantes
- Exportez vos données vers BigQuery ou Cloud Logging pour bénéficier d'analyses et de fonctionnalités avancées, comme l'interrogation de vos données, la création de tableaux de bord personnalisés et la configuration d'alertes personnalisées.