Firebase Crashlytics एक आसान और रीयल टाइम क्रैश रिपोर्टर है. इससे ऐप्लिकेशन के क्रैश या फ़्रीज़ होने से जुड़ी समस्याओं को आसानी से मैनेज किया जा सकता है. Crashlytics से, ऐप्लिकेशन के क्रैश होने की समस्याओं का ग्रुप बनाकर और उनसे जुड़ी स्थितियों को हाइलाइट करके, समस्या हल करने में लगने वाला समय बचाया जा सकता है.
इस गाइड में Crashlytics को अपने Xcode प्रोजेक्ट में इंटिग्रेट करने का तरीका बताया गया है, ताकि आप विज्ञापन रिस्पॉन्स आईडी को लॉग कर सकें. बाद में, अपने ऐप्लिकेशन में क्रैश की समस्या हल करते समय, विज्ञापन रिस्पॉन्स आईडी देखा जा सकता है. साथ ही, विज्ञापनों को ढूंढने और ब्लॉक करने के लिए, AdMob में विज्ञापन समीक्षा केंद्र का इस्तेमाल किया जा सकता है.
पहला चरण: किसी iOS ऐप्लिकेशन में Firebase जोड़ना
अगर आपको किसी क्लीन ऐप्लिकेशन से Firebase में लॉग इन करना है, तो GitHub पर iOS डेटा स्टोर करने की जगह के लिए, Google Mobile Ads SDK के उदाहरण डाउनलोड या क्लोन करें. इस गाइड में खास तौर पर, बैनर का उदाहरण इस्तेमाल किया गया है.
अगर आपके पास पहले से कोई ऐप्लिकेशन है, तो आप अपने ऐप्लिकेशन के बंडल आईडी की मदद से, अन्य चरणों पर जा सकते हैं. यही चरण, डेटा स्टोर करने की जगह के दूसरे उदाहरणों में भी लागू किए जा सकते हैं. इसके लिए, छोटे-मोटे बदलाव किए जा सकते हैं.
Firebase Crashlytics का इस्तेमाल करने के लिए, आपको एक Firebase प्रोजेक्ट बनाना होगा और उसमें अपना ऐप्लिकेशन जोड़ना होगा. अगर आपने अब तक ऐसा नहीं किया है, तो Firebase प्रोजेक्ट बनाएं. उसके लिए अपना ऐप्लिकेशन रजिस्टर करना पक्का करें.
'Firebase कंसोल' के Crashlytics पेज पर, Crashlytics सेट अप करें पर क्लिक करें.
स्क्रीन पर दिखने वाली स्क्रीन में, नहीं > नया Firebase ऐप्लिकेशन सेट अप करें पर क्लिक करें.
Podfile में, Google Analytics और Firebase Crashlytics के लिए पॉड जोड़ें.
source 'https://github.com/CocoaPods/Specs.git' platform :ios, '8.0' target 'BannerExample' do use_frameworks! pod 'Google-Mobile-Ads-SDK' pod 'Firebase/Crashlytics' pod 'Firebase/Analytics' end
Terminal या कमांड प्रॉम्प्ट में, अपने पॉड इंस्टॉल और अपडेट करें:
pod install --repo-update
प्रोजेक्ट लोड करने के लिए, Xcode के लिए
BannerExample.xcworkspace
फ़ाइल खोलें.
दूसरा चरण: अपने ऐप्लिकेशन के लिए Firebase कॉन्फ़िगर करना
Swift
अपने AppDelegate.swift
में, ये लाइनें जोड़ें:
import UIKit // Import the Firebase library import FirebaseCore @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { var window: UIWindow? func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { // Configure an instance of Firebase FirebaseApp.configure() return true } }
Objective-C
अपने AppDelegate.m
में, ये लाइनें जोड़ें:
@import AppDelegate.h; // Import the Firebase library @import FirebaseCore; @interface AppDelegate () @end @implementation AppDelegate ‐ (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // Override point for customization after application launch. // Initialize Firebase [FIRApp configure]; return YES; }
Xcode में, बिल्ड सेटिंग खोलें. इसके बाद, बिल्ड चरण टैब पर क्लिक करें. फ़ैब्रिक रन स्क्रिप्ट जोड़ें:
बिल्ड फ़ोल्डर साफ़ करें. इसके बाद, ऐप्लिकेशन बनाएं और चलाएं. अब Firebase वेब कंसोल में लॉगिन करके, Crashlytics डैशबोर्ड ऐक्सेस किया जा सकता है.
(ज़रूरी नहीं): सेटअप की जांच करना
क्रैश बटन जोड़कर आप हर बटन को दबाने से ऐप्लिकेशन क्रैश होने की समस्या को ज़बरदस्ती लागू कर सकते हैं. यह टेस्ट सेटअप, तीसरे चरण में कोड को ट्रिगर करेगा. इससे Firebase Crashlytic डैशबोर्ड पर कस्टम लॉग भेजे जा सकेंगे.
Swift
अपने ViewController.swift
में, viewDidLoad()
फ़ंक्शन में ये लाइनें जोड़ें:
override func viewDidLoad() { super.viewDidLoad() print("Google Mobile Ads SDK version: \(GADRequest.sdkVersion())") bannerView.delegate = self bannerView.adUnitID = "ca-app-pub-3940256099942544/2934735716" bannerView.rootViewController = self bannerView.load(GADRequest()) let button = UIButton(type: .roundedRect) button.frame = CGRect(x: 20, y: 50, width: 100, height: 30) button.setTitle("Crash", for: []) button.addTarget(self, action: #selector(self.crashButtonTapped(_:)), for: .touchUpInside) view.addSubview(button) }
इसके बाद, क्लास के एलान के सबसे नीचे इस @IBAction
को जोड़ें:
@IBAction func crashButtonTapped(_ sender: AnyObject) { fatalError("Test Crash Happened") }
Objective-C
अपने ViewController.m
में, viewDidLoad
तरीके में ये लाइनें जोड़ें:
‐ (void)viewDidLoad { [super viewDidLoad]; /// ... UIButton* button = [UIButton buttonWithType:UIButtonTypeRoundedRect]; button.frame = CGRectMake(20, 50, 100, 30); [button setTitle:@"Crash" forState:UIControlStateNormal]; [button addTarget:self action:@selector(crashButtonTapped:) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:button]; }
इसके बाद, क्लास के एलान के सबसे नीचे इस IBAction
को जोड़ें:
‐ (IBAction)crashButtonTapped:(id)sender { assert(NO); }
Xcode टूलबार में बंद करें बटन दबाएं. इसके बाद, सिम्युलेटर की मदद से ऐप्लिकेशन को फिर से लॉन्च करें. ऐप्लिकेशन लोड होने के बाद, क्रैश बटन पर क्लिक किया जा सकता है. Xcode पर वापस आएं और चलाएं बटन पर क्लिक करें, ताकि Crashlytics पर क्रैश लॉग अपलोड किया जा सके.
तीसरा चरण: विज्ञापन रिस्पॉन्स आईडी को लॉग करें
अगर कई विज्ञापन लोड किए जाते हैं और उन्हें अलग-अलग समय पर दिखाया जाता है, तो बेहतर होगा कि हर विज्ञापन रिस्पॉन्स आईडी को एक अलग कुंजी से लॉग करें. उदाहरण के लिए, इस गाइड में ऐसे उदाहरण का इस्तेमाल किया गया है
जिसमें सिर्फ़ एक बैनर विज्ञापन है. इसलिए, हम इस स्निपेट में विज्ञापन रिस्पॉन्स आईडी को banner_ad_response_id
कुंजी के तौर पर लॉग करते हैं.
अलग-अलग विज्ञापन टाइप और विज्ञापन इवेंट के लिए, Firebase Crashlytics में कई कस्टम कुंजी / वैल्यू के जोड़े भी बनाए जा सकते हैं. ज़्यादा जानकारी के लिए, विज्ञापन अनुरोध के लाइफ़साइकल से जुड़ी सूचनाएं देखें
कस्टम लॉगिन के बारे में ज़्यादा जानकारी के लिए, Firebase Crashlytics की क्रैश रिपोर्ट को पसंद के मुताबिक बनाएं.
Swift
अपने ViewController.swift
में यह कोड जोड़ें. यह ज़रूरी है कि यह adViewDidReceiveAd
कॉलबैक फ़ंक्शन में Crashlytics.setCustomValue()
फ़ंक्शन का इस्तेमाल करता हो.
import GoogleMobileAds import UIKit class ViewController: UIViewController, GADBannerViewDelegate { /// The banner view. @IBOutlet weak var bannerView: GADBannerView! override func viewDidLoad() { super.viewDidLoad() ... bannerView.delegate = self ... } /// Tells the delegate an ad request loaded an ad. func adViewDidReceiveAd(_ bannerView: GADBannerView) { if let responseInfo = bannerView.responseInfo, responseId = responseInfo.responseId { print("adViewDidReceiveAd from network: \(responseInfo.adNetworkClassName), response Id='\(responseId)'") Crashlytics.sharedInstance().setCustomValue(responseId, forKey: "banner_ad_response_id") } } }
Objective-C
अपने ViewController.m
में यह कोड जोड़ें. यह ज़रूरी है कि यह adViewDidReceiveAd
फ़ंक्शन में
[FIRCrashlytics crashlytics]
setCustomValue
फ़ंक्शन का इस्तेमाल करता हो.
@import GoogleMobileAds; @interface ViewController () @property(nonatomic, strong) GADBannerView *bannerView; @end @implementation ViewController ‐ (void)viewDidLoad { [super viewDidLoad]; // In this case, we instantiate the banner with desired ad size. self.bannerView = [[GADBannerView alloc] initWithAdSize:GADAdSizeBanner]; [self addBannerViewToView:self.bannerView]; } ‐ (void)addBannerViewToView:(UIView *)bannerView { bannerView.translatesAutoresizingMaskIntoConstraints = NO; [self.view addSubview:bannerView]; [self.view addConstraints:@[ [NSLayoutConstraint constraintWithItem:bannerView attribute:NSLayoutAttributeBottom relatedBy:NSLayoutRelationEqual toItem:self.bottomLayoutGuide attribute:NSLayoutAttributeTop multiplier:1 constant:0], [NSLayoutConstraint constraintWithItem:bannerView attribute:NSLayoutAttributeCenterX relatedBy:NSLayoutRelationEqual toItem:self.view kattribute:NSLayoutAttributeCenterX multiplier:1 constant:0] ]]; } - (void)adViewDidReceiveAd:(GADBannerView *)bannerView { NSString *adResponseId = bannerView.responseInfo.responseId; if (adResponseId) { NSLog(@"adViewDidReceiveAd from network: %@ with response Id: %@", bannerView.responseInfo.adNetworkClassName, adResponseId); [[FIRCrashlytics crashlytics] setCustomValue:adResponseId forKey:@"banner_ad_response_id"]; } } @end
बधाई! अब आपको अपने Crashlytics डैशबोर्ड पर, क्रैश सेशन के मुख्य सेक्शन में
हाल ही का adResponseId
दिखेगा. ध्यान रखें कि कुछ बटन को डैशबोर्ड पर दिखने
में एक घंटा लग सकता है.