根據預設,Firebase Crashlytics 會自動檢測您的 Flutter 專案,上傳必要的符號檔案,確保當機報告經過去模糊處理,且可供人類閱讀。
很抱歉,在某些情況下,專案可能無法完全設定。本指南將概略說明自動化功能的運作方式,並提供偵錯專案設定的初步步驟。
Apple 平台
檢查上傳 dSYM 檔案的設定
新增 Crashlytics Flutter 外掛程式並執行 flutterfire configure
指令後,系統會嘗試在專案的 Xcode 工作區中新增執行指令碼,以便尋找並上傳必要的 dSYM 符號檔案至 Crashlytics。如果沒有這些檔案,Crashlytics 資訊主頁會顯示「缺少 dSYM」警示,後端會保留例外狀況,直到缺少的檔案上傳為止。
如果遇到這個問題,請先確認您已安裝執行指令碼:
在專案的 iOS 目錄 (
FLUTTER_PROJECT_NAME/ios/Runner.xcworkspace
) 中找出並開啟 Xcode 工作區檔案。判斷是否已將名為
[firebase_crashlytics] Crashlytics Upload Symbols
的執行指令碼新增至 Runner 目標的建構階段。請參閱下方的適用章節,瞭解執行指令碼是否「不存在」或執行指令碼是否存在。
檢查 Flutter 和 Crashlytics 的版本設定 (如果使用 --split-debug-info
標記)
如果您的 Flutter 專案使用 --split-debug-info
標記 (以及選用的 --obfuscate
標記),就必須採取額外步驟,才能顯示應用程式的可讀堆疊追蹤記錄。
請確認專案使用建議的版本設定 (Flutter 3.12.0 以上版本和 Crashlytics Flutter 外掛程式 3.3.4 以上版本),以便專案自動產生並上傳 Flutter 符號 (dSYM 檔案) 至 Crashlytics。
Android
檢查依附元件設定
flutterfire configure
指令會嘗試在專案的 Gradle 建構檔案中新增必要的依附元件。如果沒有這些依附元件,如果啟用模糊處理功能,Firebase 主控台中的當機報告可能會遭到模糊處理。
請確認專案層級 build.gradle
和應用程式層級 build.gradle
中包含下列程式碼行:
在專案層級的建構檔案 (
android/build.gradle
) 中,檢查以下行:dependencies { // ... other dependencies classpath 'com.google.gms:google-services:4.3.5' classpath 'com.google.firebase:firebase-crashlytics-gradle:2.7.1' }
在應用程式層級的建構檔案 (
android/app/build.gradle
) 中,檢查以下這行:// ... other imports android { // ... your android config } dependencies { // ... your dependencies } // This section must appear at the bottom of the file apply plugin: 'com.google.gms.google-services' apply plugin: 'com.google.firebase.crashlytics'
確認您使用 CLI 上傳 Flutter 符號(如果使用 --split-debug-info
標記)
如果您的 Flutter 專案使用 --split-debug-info
標記 (以及選用的 --obfuscate
標記),就必須採取額外步驟,才能顯示應用程式的可讀堆疊追蹤記錄。
使用 Firebase CLI (v.11.9.0 以上版本) 上傳 Flutter 偵錯符號。您必須在從模糊處理的程式碼版本回報當機事件之前,先上傳偵錯符號。
在 Flutter 專案的根目錄中執行下列指令:
firebase crashlytics:symbols:upload --app=FIREBASE_APP_ID PATH/TO/symbols
FIREBASE_APP_ID:您的 Firebase Android 應用程式 ID (非套件名稱)
Firebase Android 應用程式 ID 範例:1:567383003300:android:17104a2ced0c9b9b
PATH/TO/symbols
:建構應用程式時傳遞至--split-debug-info
標記的相同目錄
如果問題仍未解決,請參閱 Android 專用指南,瞭解如何排解模糊化報表的問題。