این راهنمای سریع نحوه راهاندازی 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)، به گزارشهای خرابی رفع ابهامشده مراجعه کنید.
مرحله ۳ : برای اتمام راهاندازی، یک کرش آزمایشی را اعمال کنید
برای تکمیل راهاندازی Crashlytics و مشاهده دادههای اولیه در داشبورد Crashlytics کنسول Firebase ، باید یک crash آزمایشی را اجباری کنید.
کدی را به برنامه خود اضافه کنید که بتوانید از آن برای ایجاد خطای تست استفاده کنید.
شما میتوانید از کد زیر برای اضافه کردن دکمهای به برنامه خود استفاده کنید که با فشردن آن، برنامه از کار بیفتد. این دکمه با عنوان "تست کرش" نامگذاری شده است.
سویفتیوآی
Button("Crash") { fatalError("Crash was triggered") }
رابط کاربری
سویفت
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
برنامه خود را در Xcode و در حالی که اشکالزدای Xcode غیرفعال است، بسازید و اجرا کنید.
روی Build کلیک کنید و سپس طرح فعلی را اجرا کنید تا برنامه شما روی یک دستگاه آزمایشی یا شبیهساز ساخته شود.
صبر کنید تا برنامه شما اجرا شود، سپس روی اجرای طرح یا اقدام» کلیک کنید تا نمونه اولیه برنامه شما بسته شود. این نمونه اولیه شامل اشکالزدایی است که با Crashlytics تداخل دارد.
برای ارسال اولین گزارش خرابی برنامهتان، تست کرش را اجباری کنید:
برنامه خود را از صفحه اصلی دستگاه تست یا شبیهساز خود باز کنید.
در برنامهتان، دکمهی «تست کرش» را که با استفاده از کد بالا اضافه کردهاید، فشار دهید.
پس از اینکه برنامه شما از کار افتاد، دوباره آن را از Xcode اجرا کنید تا برنامه شما بتواند گزارش خرابی را به Firebase ارسال کند.
برای مشاهدهی خرابی آزمایشی خود، به داشبورد Crashlytics در کنسول Firebase بروید.
اگر کنسول را رفرش کردهاید و هنوز بعد از پنج دقیقه خطای آزمایشی را مشاهده نمیکنید، گزارشگیری اشکالزدایی را فعال کنید تا ببینید آیا برنامه شما گزارشهای خرابی را ارسال میکند یا خیر.
و تمام! Crashlytics اکنون برنامه شما را برای یافتن خرابیها رصد میکند. برای مشاهده و بررسی تمام گزارشها و آمار خود، به داشبورد Crashlytics مراجعه کنید.
مراحل بعدی
- با افزودن گزارشهای اختیاری، گزارشهای لاگ، کلیدها و ردیابی خطاهای غیرمهلک ، تنظیمات گزارش خرابی خود را سفارشی کنید .