این راهنمای سریع نحوه راهاندازی Firebase Crashlytics در برنامه شما با Firebase Crashlytics SDK را شرح میدهد تا بتوانید گزارشهای جامعی از خرابیها را در کنسول Firebase دریافت کنید.
راهاندازی Crashlytics نیازمند انجام وظایفی هم در کنسول Firebase و هم در IDE شما است (مانند اضافه کردن فایل پیکربندی Firebase و Crashlytics SDK). برای تکمیل راهاندازی، باید یک کرش آزمایشی را مجبور کنید تا اولین گزارش کرش شما را به Firebase ارسال کند.
قبل از اینکه شروع کنی
اگر هنوز فایربیس را به پروژه اپل خود اضافه نکردهاید، آن را اضافه کنید . اگر برنامه اپل ندارید، میتوانید یک برنامه نمونه را دانلود کنید.
توصیه میشود : برای اینکه گزارشهای breadcrumb به طور خودکار اقدامات کاربر را که منجر به خرابی، عدم موفقیت یا رویداد ANR میشود، درک کنند، باید Google Analytics در پروژه Firebase خود فعال کنید.
اگر پروژه Firebase فعلی شما Google Analytics فعال نکرده است، میتوانید Google Analytics از تب Integrations فعال کنید.
> تنظیمات پروژه در کنسول Firebase . اگر در حال ایجاد یک پروژه جدید Firebase هستید، در طول فرآیند ایجاد پروژه، Google Analytics فعال کنید.
توجه داشته باشید که گزارشهای breadcrumb برای همه پلتفرمهای اپل که توسط Crashlytics پشتیبانی میشوند، به جز watchOS، در دسترس هستند.
مرحله ۱ : Crashlytics SDK را به برنامه خود اضافه کنید
برای نصب و مدیریت وابستگیهای Firebase از Swift Package Manager استفاده کنید.
- در Xcode، با باز کردن پروژه برنامه خود، به File > Add Packages بروید.
- وقتی از شما خواسته شد، مخزن SDK پلتفرمهای اپل فایربیس را اضافه کنید:
- کتابخانه Crashlytics را انتخاب کنید.
- برای استفاده از گزارشهای breadcrumb ، کیت توسعه نرمافزار Firebase برای Google Analytics را نیز به برنامه خود اضافه کنید. مطمئن شوید که گوگل آنالیتیکس در پروژه فایربیس شما فعال است .
- پرچم
-ObjCرا به بخش Other Linker Flags در تنظیمات ساخت هدف خود اضافه کنید. - (فقط macOS) در
Info.plistخود، کلیدNSApplicationCrashOnExceptionsرا اضافه کنید و آن را رویYESتنظیم کنید. - پس از اتمام، Xcode به طور خودکار شروع به حل و دانلود وابستگیهای شما در پسزمینه میکند.
https://github.com/firebase/firebase-ios-sdk.git
سپس، ماژول Firebase را پیکربندی کنید:
ماژول Firebase را در
Appstruct یاUIApplicationDelegateخود وارد کنید:سویفت
import Firebase
هدف-سی
@import Firebase;
یک نمونه اشتراکی
FirebaseAppرا پیکربندی کنید، که معمولاً درapplication(_:didFinishLaunchingWithOptions:)نماینده برنامه شما قرار دارد:سویفت
// Use the Firebase library to configure APIs. FirebaseApp.configure()
هدف-سی
// Use the Firebase library to configure APIs. [FIRApp configure];
مرحله 2 : Xcode را برای آپلود خودکار فایلهای dSYM تنظیم کنید
برای تولید گزارشهای خرابی قابل خواندن توسط انسان، Crashlytics به فایلهای نماد اشکالزدایی (dSYM) پروژه شما نیاز دارد. مراحل زیر نحوه پیکربندی Xcode را برای تولید خودکار dSYM های شما، پردازش آنها و آپلود فایلها در هر زمان ساخت برنامه شرح میدهد.
فضای کاری Xcode پروژه خود را باز کنید، سپس فایل پروژه آن را در نوار ناوبری سمت چپ انتخاب کنید.
از لیست TARGETS ، هدف اصلی ساخت خود را انتخاب کنید.
روی تب Build Settings کلیک کنید، سپس مراحل زیر را انجام دهید تا Xcode برای buildهای شما dSYM تولید کند.
روی همه کلیک کنید، سپس
debug information formatرا جستجو کنید.برای همه انواع ساخت خود ، قالب اطلاعات اشکالزدایی را روی
DWARF with dSYM Fileتنظیم کنید.
روی تب Build Phases کلیک کنید، سپس مراحل زیر را انجام دهید تا Xcode بتواند dSYM های شما را پردازش کرده و فایل ها را آپلود کند.
روی > مرحله اجرای اسکریپت جدید کلیک کنید.
مطمئن شوید که این مرحلهی جدید اجرای اسکریپت، آخرین مرحلهی ساخت پروژهی شما باشد؛ در غیر این صورت، Crashlytics نمیتواند dSYMها را به درستی پردازش کند.
بخش جدید Run Script را باز کنید.
در فیلد اسکریپت (واقع در زیر برچسب Shell )، اسکریپت اجرایی زیر را اضافه کنید.
این اسکریپت فایلهای dSYM پروژه شما را پردازش کرده و آنها را در Crashlytics آپلود میکند.
"${BUILD_DIR%/Build/*}/SourcePackages/checkouts/firebase-ios-sdk/Crashlytics/run"در بخش فایلهای ورودی ، مسیرهای مربوط به مکان فایلهای زیر را اضافه کنید:
${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)
ENABLE_USER_SCRIPT_SANDBOXING=YESوENABLE_DEBUG_DYLIB=YESدارید، موارد زیر را وارد کنید:${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Resources/DWARF/${PRODUCT_NAME}.debug.dylib
برای اطلاعات بیشتر در مورد فایلهای dSYM و Crashlytics (از جمله نحوه آپلود دستی فایلهای dSYM)، به گزارشهای خرابی رفع ابهامشده مراجعه کنید.
Step 3 : Force a test crash to finish setup
To finish setting up Crashlytics and see initial data in the Crashlytics dashboard of the Firebase console, you need to force a test crash.
Add code to your app that you can use to force a test crash.
You can use the following code to add a button to your app that, when pressed, causes a crash. The button is labeled "Test Crash".
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] } }
هدف-سی
#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
Build and run your app in Xcode with the Xcode debugger disconnected.
Click Build and then run the current scheme to build your app on a test device or simulator.
Wait until your app is running, then click Stop running the scheme or action to close the initial instance of your app. This initial instance included the debugger that interferes with Crashlytics .
Force the test crash in order to send your app's first crash report:
Open your app from the home screen of your test device or simulator.
In your app, press the "Test Crash" button that you added using the code above.
After your app crashes, run it again from Xcode so that your app can send the crash report to Firebase.
Go to the Crashlytics dashboard of the Firebase console to see your test crash.
If you've refreshed the console and you're still not seeing the test crash after five minutes, enable debug logging to see if your app is sending crash reports.
And that's it! Crashlytics is now monitoring your app for crashes. Visit the Crashlytics dashboard to view and investigate all your reports and statistics.
مراحل بعدی
- Customize your crash report setup by adding opt-in reporting, logs, keys, and tracking of non-fatal errors.