התחל עם Firebase Crashlytics

התחלה מהירה זו מתארת ​​כיצד להגדיר את Firebase Crashlytics באפליקציה שלך עם Firebase Crashlytics SDK כדי שתוכל לקבל דוחות קריסה מקיפים במסוף Firebase.

הגדרת Crashlytics דורשת משימות הן במסוף Firebase והן ב-IDE שלך (כמו הוספת קובץ תצורה של Firebase ו-Crashlytics SDK). כדי לסיים את ההגדרה, תצטרך לאלץ קריסת בדיקה כדי לשלוח את דוח הקריסה הראשון שלך ל-Firebase.

לפני שאתה מתחיל

  1. אם עדיין לא עשית זאת, הוסף את Firebase לפרויקט Apple שלך. אם אין לך אפליקציה של אפל, תוכל להוריד אפליקציה לדוגמה .

  2. מומלץ : כדי לקבל אוטומטית יומני פירורי לחם כדי להבין את פעולות המשתמש המובילות לקריסה, לא קטלנית או אירוע ANR, עליך להפעיל את Google Analytics בפרויקט Firebase שלך.

    • אם בפרויקט Firebase הקיים שלך לא מופעל Google Analytics, תוכל להפעיל את Google Analytics מהכרטיסייה אינטגרציות של > הגדרות פרויקט במסוף Firebase.

    • אם אתה יוצר פרויקט Firebase חדש, הפעל את Google Analytics במהלך תהליך העבודה של יצירת הפרויקט.

    שימו לב שיומני פירורי לחם זמינים עבור כל הפלטפורמות של אפל הנתמכות על ידי Crashlytics למעט watchOS.

שלב 1 : הוסף את ה-SDK של Crashlytics לאפליקציה שלך

השתמש ב- Swift Package Manager כדי להתקין ולנהל תלות ב-Firebase.

  1. ב-Xcode, כשפרויקט האפליקציה שלך פתוח, נווט אל קובץ > הוסף חבילות .
  2. כשתתבקש, הוסף את מאגר Firebase Apple platforms SDK:
  3.   https://github.com/firebase/firebase-ios-sdk.git
  4. בחר את ספריית Crashlytics.
  5. כדי לנצל את יומני פירורי הלחם , הוסף גם את Firebase SDK עבור Google Analytics לאפליקציה שלך. ודא ש- Google Analytics מופעל בפרויקט Firebase שלך.
  6. הוסף את הדגל -ObjC לקטע Other Linker Flags של הגדרות הבנייה של היעד שלך.
  7. (macOS בלבד) ב- Info.plist שלך, הוסף את המפתח NSApplicationCrashOnExceptions והגדר אותו ל- YES .
  8. בסיום, Xcode יתחיל באופן אוטומטי לפתור ולהוריד את התלות שלך ברקע.

לאחר מכן, הגדר את מודול Firebase:

  1. ייבא את מודול Firebase במבנה App שלך או UIApplicationDelegate :

    מָהִיר

    import Firebase

    Objective-C

    @import Firebase;
  2. הגדר מופע משותף FirebaseApp , בדרך כלל בשיטת application(_:didFinishLaunchingWithOptions:) של נציג האפליקציה שלך:

    מָהִיר

    // Use the Firebase library to configure APIs.
    FirebaseApp.configure()
    

    Objective-C

    // Use the Firebase library to configure APIs.
    [FIRApp configure];
    

שלב 2 : הגדר את Xcode להעלאה אוטומטית של קבצי dSYM

כדי להפיק דוחות קריאות קריאות אנושיים, Crashlytics זקוק לקבצי סמל ניפוי באגים (dSYM) של הפרויקט שלך. השלבים הבאים מתארים כיצד להגדיר את Xcode לייצר באופן אוטומטי את ה-dSYMs שלך, לעבד אותם ולהעלות את הקבצים בכל פעם שאתה בונה את האפליקציה שלך.

  1. פתח את סביבת העבודה Xcode של הפרויקט שלך, ולאחר מכן בחר את קובץ הפרויקט שלו בנווט השמאלי.

  2. מרשימת היעדים , בחר את יעד הבנייה הראשי שלך.

  3. לחץ על הכרטיסייה Build Settings , ולאחר מכן השלם את השלבים הבאים כדי ש-Xcode יפיק dSYMs עבור ה-builds שלך.

    1. לחץ על הכל ולאחר מכן חפש debug information format .

    2. הגדר את פורמט מידע ניפוי באגים ל- DWARF with dSYM File עבור כל סוגי הבנייה שלך.

  4. לחץ על הכרטיסייה Build Phases , ולאחר מכן השלם את השלבים הבאים כדי ש-Xcode יוכל לעבד את ה-dSYMs שלך ולהעלות את הקבצים.

    1. לחץ על > שלב הפעלת סקריפט חדש .

      ודא ששלב ההפעלה החדש הזה הוא שלב הבנייה האחרון של הפרויקט שלך; אחרת, Crashlytics לא יכולה לעבד כראוי dSYMs.

    2. הרחב את הקטע החדש של הפעלת סקריפט .

    3. בשדה הסקריפט (הממוקם תחת התווית Shell ), הוסף את סקריפט ההרצה הבא.

      סקריפט זה מעבד את קבצי dSYM של הפרויקט שלך ומעלה את הקבצים ל-Crashlytics.

      "${BUILD_DIR%/Build/*}/SourcePackages/checkouts/firebase-ios-sdk/Crashlytics/run"
    4. במקטע קבצי קלט , הוסף את הנתיבים עבור המיקומים של הקבצים הבאים:

      ${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}
      ${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Resources/DWARF/${PRODUCT_NAME}
      ${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Info.plist
      $(TARGET_BUILD_DIR)/$(UNLOCALIZED_RESOURCES_FOLDER_PATH)/GoogleService-Info.plist
      $(TARGET_BUILD_DIR)/$(EXECUTABLE_PATH)

למידע מפורט יותר על קבצי dSYM ו-Crashlytics (כולל כיצד להעלות קבצי dSYM באופן ידני), בקר בקבל דוחות קריסה מעורפלים .

שלב 3 : כפה קריסת בדיקה כדי לסיים את ההגדרה

כדי לסיים את הגדרת Crashlytics ולראות נתונים ראשוניים בלוח המחוונים של Crashlytics של קונסולת Firebase, עליך לאלץ קריסת מבחן.

  1. הוסף קוד לאפליקציה שלך שבו תוכל להשתמש כדי לאלץ קריסת מבחן.

    אתה יכול להשתמש בקוד הבא כדי להוסיף לחצן לאפליקציה שלך, שכאשר לוחצים עליו, גורם לקריסה. הכפתור מסומן "קריסת בדיקה".

    SwiftUI

    Button("Crash") {
      fatalError("Crash was triggered")
    }
    

    UIKit

    מָהִיר

    import UIKit
    
    class ViewController: UIViewController {
      override func viewDidLoad() {
          super.viewDidLoad()
    
          // Do any additional setup after loading the view, typically from a nib.
    
          let button = UIButton(type: .roundedRect)
          button.frame = CGRect(x: 20, y: 50, width: 100, height: 30)
          button.setTitle("Test Crash", for: [])
          button.addTarget(self, action: #selector(self.crashButtonTapped(_:)), for: .touchUpInside)
          view.addSubview(button)
      }
    
      @IBAction func crashButtonTapped(_ sender: AnyObject) {
          let numbers = [0]
          let _ = numbers[1]
      }
    }
    

    Objective-C

    #import "ViewController.h"
    
    @implementation ViewController
    ‐ (void)viewDidLoad {
        [super viewDidLoad];
    
        // Do any additional setup after loading the view, typically from a nib.
    
        UIButton* button = [UIButton buttonWithType:UIButtonTypeRoundedRect];
        button.frame = CGRectMake(20, 50, 100, 30);
        [button setTitle:@"Test Crash" forState:UIControlStateNormal];
        [button addTarget:self action:@selector(crashButtonTapped:)
            forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:button];
    }
    
    ‐ (IBAction)crashButtonTapped:(id)sender {
        @[][1];
    }
    
    @end
    
  2. בנה והפעל את האפליקציה שלך ב-Xcode עם מאפר הבאגים של Xcode מנותק.

    1. לחץ על Build ולאחר מכן הפעל את הסכימה הנוכחית כדי לבנות את האפליקציה שלך במכשיר בדיקה או סימולטור.

    2. המתן עד שהאפליקציה שלך תפעל, ואז לחץ על הפסק להפעיל את הסכימה או הפעולה כדי לסגור את המופע הראשוני של האפליקציה שלך. המקרה הראשוני הזה כלל את מאתר הבאגים שמפריע ל-Crashlytics.

  3. כפה את קריסת הבדיקה כדי לשלוח את דוח הקריסה הראשון של האפליקציה שלך:

    1. פתח את האפליקציה שלך ממסך הבית של מכשיר הבדיקה או הסימולטור שלך.

    2. באפליקציה שלך, לחץ על כפתור "Test Crash" שהוספת באמצעות הקוד שלמעלה.

    3. לאחר שהאפליקציה שלך קורסת, הפעל אותה שוב מ-Xcode כדי שהאפליקציה שלך תוכל לשלוח את דוח הקריסה ל-Firebase.

  4. עבור אל לוח המחוונים של Crashlytics של מסוף Firebase כדי לראות את קריסת המבחן שלך.

    אם רענן את המסוף ואתה עדיין לא רואה את קריסת הבדיקה לאחר חמש דקות, הפעל רישום באגים כדי לראות אם האפליקציה שלך שולחת דוחות קריסה.


וזה הכל! Crashlytics עוקב כעת אחר האפליקציה שלך לאיתור קריסות. בקר במרכז השליטה של ​​Crashlytics כדי להציג ולחקור את כל הדוחות והסטטיסטיקות שלך.

הצעדים הבאים

,

התחלה מהירה זו מתארת ​​כיצד להגדיר את Firebase Crashlytics באפליקציה שלך עם Firebase Crashlytics SDK כדי שתוכל לקבל דוחות קריסה מקיפים במסוף Firebase.

הגדרת Crashlytics דורשת משימות הן במסוף Firebase והן ב-IDE שלך (כמו הוספת קובץ תצורה של Firebase ו-Crashlytics SDK). כדי לסיים את ההגדרה, תצטרך לאלץ קריסת בדיקה כדי לשלוח את דוח הקריסה הראשון שלך ל-Firebase.

לפני שאתה מתחיל

  1. אם עדיין לא עשית זאת, הוסף FireBase לפרויקט Apple שלך. אם אין לך אפליקציית Apple, אתה יכול להוריד אפליקציה לדוגמא .

  2. מומלץ : כדי לקבל אוטומטית יומני פירורי לחם כדי להבין פעולות משתמש המובילות לאירוע התרסקות, לא קטלני או ANR, עליך לאפשר Google Analytics בפרויקט Firebase שלך.

    • אם פרויקט ה- Firebase הקיים שלך אינו מופעל ב- Google Analytics, אתה יכול לאפשר Google Analytic > הגדרות פרויקט במסוף Firebase.

    • אם אתה יוצר פרויקט Firebase חדש, הפעל את Google Analytics במהלך זרימת העבודה של יצירת הפרויקט.

    שים לב כי יומני פירורי לחם זמינים לכל פלטפורמות Apple הנתמכות על ידי Crashlytics למעט WatchOS.

שלב 1 : הוסף את ה- Crashlytics SDK לאפליקציה שלך

השתמש במנהל חבילות Swift כדי להתקין ולנהל תלות Firebase.

  1. ב- Xcode, כאשר פרויקט האפליקציה שלך פתוח, נווט אל קובץ> הוסף חבילות .
  2. כאשר מתבקשים, הוסף את מאגר ה- SDK של Firebase Apple SDK:
  3.   https://github.com/firebase/firebase-ios-sdk.git
  4. בחר בספריית Crashlytics.
  5. כדי לנצל את יומני פירורי הלחם , הוסף גם את ה- Firebase SDK עבור Google Analytics לאפליקציה שלך. וודא ש- Google Analytics מופעלת בפרויקט Firebase שלך.
  6. הוסף את דגל -ObjC לקטע של דגלי הקישור האחרים בהגדרות הבנייה של היעד שלך.
  7. (MacOS בלבד) ב- Info.plist שלך, הוסף את המפתח NSApplicationCrashOnExceptions והגדר אותו ל- YES .
  8. בסיום, Xcode יתחיל אוטומטית לפתור ולהוריד את התלות שלך ברקע.

בשלב הבא, קבע את התצורה של מודול FireBase:

  1. ייבא את מודול FireBase במבנה App שלך או UIApplicationDelegate :

    מָהִיר

    import Firebase

    Obstive-C

    @import Firebase;
  2. קבע תצורה של מופע משותף FirebaseApp , בדרך כלל application(_:didFinishLaunchingWithOptions:) שיטה:

    מָהִיר

    // Use the Firebase library to configure APIs.
    FirebaseApp.configure()
    

    Obstive-C

    // Use the Firebase library to configure APIs.
    [FIRApp configure];
    

שלב 2 : הגדר XCode כדי להעלות אוטומטית קבצי DSYM

כדי ליצור דוחות קריסה קריאים אנושיים, Crashlytics זקוקה לקבצי סמל הבאגים של הפרויקט שלך (DSYM). השלבים הבאים מתארים כיצד להגדיר את תצורת XCode כדי לייצר אוטומטית את ה- DSYMS שלך, לעבד אותם ולהעלות את הקבצים בכל פעם שאתה בונה את האפליקציה שלך.

  1. פתח את סביבת העבודה של ה- XCode של הפרויקט שלך, ואז בחר את קובץ הפרויקט שלו בנווט השמאלי.

  2. מרשימת היעדים , בחר את יעד הבנייה הראשי שלך.

  3. לחץ על הכרטיסייה הגדרות Build , ואז מלא את הצעדים הבאים כך ש- Xcode יפיק DSYMS לבנייה שלך.

    1. לחץ על הכל , ואז חפש את debug information format .

    2. הגדר את פורמט המידע של ניפוי באגים DWARF with dSYM File עבור כל סוגי הבנייה שלך.

  4. לחץ על הכרטיסייה שלבי Build , ואז מלא את השלבים הבאים כך ש- XCode יוכל לעבד את ה- DSYMS שלך ולהעלות את הקבצים.

    1. לחץ על > שלב סקריפט הפעל חדש .

      וודא שלב סקריפט ריצה חדש זה הוא שלב הבנייה האחרון של הפרויקט שלך; אחרת, Crashlytics לא יכול לעבד כראוי DSYMS.

    2. הרחב את קטע סקריפט הריצה החדש.

    3. בשדה הסקריפט (הממוקם מתחת לתווית הקליפה ), הוסף את סקריפט ההפעלה הבא.

      סקריפט זה מעבד את קבצי ה- DSYM של הפרויקט שלך ומעלה את הקבצים ל- Crashlytics.

      "${BUILD_DIR%/Build/*}/SourcePackages/checkouts/firebase-ios-sdk/Crashlytics/run"
    4. בסעיף קבצי הקלט , הוסף את הנתיבים למיקומי הקבצים הבאים:

      ${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}
      ${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Resources/DWARF/${PRODUCT_NAME}
      ${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Info.plist
      $(TARGET_BUILD_DIR)/$(UNLOCALIZED_RESOURCES_FOLDER_PATH)/GoogleService-Info.plist
      $(TARGET_BUILD_DIR)/$(EXECUTABLE_PATH)

למידע מפורט יותר על קבצי DSYM ו- Crashlytics (כולל כיצד להעלות ידנית קבצי DSYM), בקרו בדוחות ההתרסקות של Deobfuscated .

שלב 3 : להכריח התרסקות מבחן כדי לסיים את ההתקנה

כדי לסיים את הגדרת Crashlytics ולראות נתונים ראשוניים בלוח המחוונים Crashlytics של קונסולת Firebase, עליך לכפות תאונת בדיקה.

  1. הוסף קוד לאפליקציה שלך שתוכל להשתמש בו כדי לכפות את תאונת הבדיקה.

    אתה יכול להשתמש בקוד הבא כדי להוסיף כפתור לאפליקציה שלך, שכאשר לוחצים עליו גורמת להתרסקות. הכפתור מכונה "התרסקות מבחן".

    סוויפטוי

    Button("Crash") {
      fatalError("Crash was triggered")
    }
    

    UIKIT

    מָהִיר

    import UIKit
    
    class ViewController: UIViewController {
      override func viewDidLoad() {
          super.viewDidLoad()
    
          // Do any additional setup after loading the view, typically from a nib.
    
          let button = UIButton(type: .roundedRect)
          button.frame = CGRect(x: 20, y: 50, width: 100, height: 30)
          button.setTitle("Test Crash", for: [])
          button.addTarget(self, action: #selector(self.crashButtonTapped(_:)), for: .touchUpInside)
          view.addSubview(button)
      }
    
      @IBAction func crashButtonTapped(_ sender: AnyObject) {
          let numbers = [0]
          let _ = numbers[1]
      }
    }
    

    Obstive-C

    #import "ViewController.h"
    
    @implementation ViewController
    ‐ (void)viewDidLoad {
        [super viewDidLoad];
    
        // Do any additional setup after loading the view, typically from a nib.
    
        UIButton* button = [UIButton buttonWithType:UIButtonTypeRoundedRect];
        button.frame = CGRectMake(20, 50, 100, 30);
        [button setTitle:@"Test Crash" forState:UIControlStateNormal];
        [button addTarget:self action:@selector(crashButtonTapped:)
            forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:button];
    }
    
    ‐ (IBAction)crashButtonTapped:(id)sender {
        @[][1];
    }
    
    @end
    
  2. בנה והפעל את האפליקציה שלך ב- Xcode כאשר Debugger של Xcode מנותק.

    1. לחץ על Build ואז הפעל את התוכנית הנוכחית כדי לבנות את האפליקציה שלך במכשיר מבחן או בסימולטור.

    2. המתן עד שהאפליקציה שלך פועלת, ואז לחץ על הפסק להפעיל את התוכנית או הפעולה כדי לסגור את המופע הראשוני של האפליקציה שלך. מופע ראשוני זה כלל את הבאגים שמפריע להתרסקות.

  3. כפה את התרסקות הבדיקה על מנת לשלוח את דוח ההתרסקות הראשון של האפליקציה שלך:

    1. פתח את האפליקציה שלך ממסך הבית של מכשיר הבדיקה או הסימולטור שלך.

    2. באפליקציה שלך, לחץ על כפתור "התרסקות הבדיקה" שהוספת באמצעות הקוד שלמעלה.

    3. לאחר שהאפליקציה שלך קורסת, הפעל אותה שוב מ- Xcode כדי שהאפליקציה שלך תוכל לשלוח את דוח ההתרסקות ל- Firebase.

  4. עבור אל לוח המחוונים Crashlytics של קונסולת Firebase כדי לראות את התרסקות הבדיקה שלך.

    אם רעננת את הקונסולה ואתה עדיין לא רואה את התרסקות הבדיקה לאחר חמש דקות, אפשר רישום באגים כדי לבדוק אם האפליקציה שלך שולחת דוחות קריסה.


וזה הכל! Crashlytics עוקב כעת אחר האפליקציה שלך להתרסקויות. בקר בלוח המחוונים Crashlytics כדי להציג ולחקור את כל הדוחות והסטטיסטיקה שלך.

הצעדים הבאים