Firebase Installations Service (FIS), bir Firebase uygulamasının yüklenen her örneği için Firebase kurulum kimliği (FID) sağlar. Firebase Kurulum kimliği, şu Firebase hizmetleri tarafından dahili olarak kullanılır:
| Firebase hizmeti | Firebase yükleme işlevi |
|---|---|
| Firebase Cloud Messaging |
Firebase Cloud Messaging, mesaj yayınında cihazları hedeflemek için Firebase yükleme kimliklerini kullanır. |
| Firebase Crashlytics |
Firebase Crashlytics, uygulama örneğinin Firebase yükleme kimliğinde yapılan değişikliklere göre Crashlytics yükleme UUID'sini döndürür. Gelecekte, yükleme kimliği kilitlenme raporlama ve kilitlenme yönetimi hizmetlerini geliştiren özellikleri etkinleştirmek için kullanılabilir. |
| Firebase In-App Messaging |
Firebase In-App Messaging, mesaj yayınında cihazları hedeflemek için Firebase yükleme kimliklerini kullanır. |
| Firebase Performance Monitoring |
Performance Monitoring, ağ kaynaklarına erişen benzersiz Firebase yüklemelerinin sayısını hesaplamak ve erişim kalıplarının yeterince anonim olmasını sağlamak için Firebase yükleme kimliklerini kullanır. Ayrıca, performans etkinliği raporlama hızını yönetmek için Firebase yükleme kimliklerini Firebase Remote Config ile birlikte kullanır. |
| Firebase Remote Config |
Remote Config, son kullanıcı cihazlarına döndürülecek yapılandırma değerlerini seçmek için Firebase yükleme kimliklerini kullanır. |
| Firebase ML |
Firebase ML, uygulama örnekleriyle etkileşimde bulunurken cihaz kimlik doğrulaması için yükleme kimlik doğrulama jetonları adlı kimlik bilgilerini kullanır. Örneğin, geliştirici modellerini uygulama örneklerine dağıtmak için bu kimlik bilgilerinden yararlanır. |
| Firebase Kullanıcı Segmentasyonu Depolama Alanı |
Firebase Kullanıcı Segmentasyonu Depolama Alanı, Firebase yükleme kimliklerini ve ilgili özellikleri ve segmentleri depolayarak bunları kullanan diğer Firebase hizmetlerine hedefleme bilgileri sağlar. |
Genellikle Firebase hizmetleri, geliştiricilerin FIS API ile doğrudan etkileşim kurmasını gerektirmeden Firebase installations hizmetini kullanır. Ancak uygulama geliştiricilerin FIS API'yi doğrudan çağırmak isteyebileceği durumlar vardır. Örneğin:
- Firebase yüklemesini ve yüklemeyle ilişkili verileri silmek için.
- Belirli uygulama yüklemelerini hedeflemek için tanımlayıcıları (Firebase yükleme kimlikleri) almak üzere.
- Firebase yüklemelerinin kimliğini doğrulamak için yükleme kimlik doğrulama jetonlarını almak üzere kullanılır.
Doğrudan FIS API'sini çağırmaya başlamak için SDK'yı uygulamanıza ekleyin.
Uygulamanıza Firebase yükleme SDK'sını ekleyin
iOS+
- Firebase yüklemeleri için bağımlılığı Podfile dosyanıza ekleyin:
pod 'FirebaseInstallations'
pod installkomutunu çalıştırın ve oluşturulan.xcworkspacedosyasını açın.FirebaseCoremodülünüUIApplicationDelegatedosyanıza ve uygulama temsilcinizin kullandığı diğer Firebase modüllerine aktarın. Örneğin, Cloud Firestore ve Authentication kullanmak için:SwiftUI
import SwiftUI import FirebaseCore import FirebaseFirestore import FirebaseAuth // ...
Swift
import FirebaseCore import FirebaseFirestore import FirebaseAuth // ...
Objective-C
@import FirebaseCore; @import FirebaseFirestore; @import FirebaseAuth; // ...
- Uygulama temsilcinizin
application(_:didFinishLaunchingWithOptions:)yönteminde paylaşılan birFirebaseAppörneği yapılandırın:SwiftUI
// Use Firebase library to configure APIs FirebaseApp.configure()
Swift
// Use Firebase library to configure APIs FirebaseApp.configure()
Objective-C
// Use Firebase library to configure APIs [FIRApp configure];
- SwiftUI kullanıyorsanız bir uygulama temsilcisi oluşturup
AppyapınızlaUIApplicationDelegateAdaptorveyaNSApplicationDelegateAdaptoraracılığıyla ilişkilendirmeniz gerekir. Ayrıca uygulama temsilcisi karıştırmayı da devre dışı bırakmanız gerekir. Daha fazla bilgi için SwiftUI talimatlarına bakın.SwiftUI
@main struct YourApp: App { // register app delegate for Firebase setup @UIApplicationDelegateAdaptor(AppDelegate.self) var delegate var body: some Scene { WindowGroup { NavigationView { ContentView() } } } }
Android
Firebase Installations Android SDK'sına ait bağımlılığı modülünüzün (uygulama düzeyinde) Gradle dosyasına (genellikle app/build.gradle) ekleyin:
implementation 'com.google.firebase:firebase-installations:19.1.0'
JavaScript
Web uygulamanızın nasıl barındırıldığına bağlı olarak yapılandırmanız otomatik olarak işlenebilir veya Firebase yapılandırma nesnenizi güncellemeniz gerekebilir.
Örneğin, bağımlılıklarınız index.html'ye eklenmişse bağımlılığı <head> öğesine ekleyin:
<script src="/__/firebase/12.12.0/firebase-installations.js"></script>
Flutter
Flutter projenizin kök dizininden aşağıdaki komutu çalıştırarak Firebase installations eklentisini yükleyin:
flutter pub add firebase_app_installationsProjenizi yeniden oluşturun:
flutter runFirebase installations eklentisini içe aktarın:
import 'package:firebase_app_installations/firebase_app_installations.dart';
Firebase yüklemesini silme
Bir Firebase yüklemesine bağlı veriler genellikle kişisel olarak tanımlayıcı değildir. Bununla birlikte, kullanıcılara bu verileri yönetme ve silme seçeneği sunmak faydalı olabilir.
Firebase yükleme kimlikleri, her uygulamanın her yüklemesi için farklıdır. Aynı cihazdaki farklı uygulamaların farklı Firebase yükleme kimlikleri vardır. Firebase yükleme kimlikleri, uygulama yüklemelerini ve bu uygulama yüklemeleriyle ilişkili verileri tanımlar.
Bir yükleme kimliğini sildiğinizde, yüklemeleri tanımlamak için Firebase yükleme kimliklerini kullanan tüm Firebase hizmetlerinin canlı ve yedekleme sistemlerinden bu yükleme kimliğiyle ilişkili veriler 180 gün içinde kaldırılır. Bu işlem, Google'ın silme ve saklama ile ilgili beyanında genel hatlarıyla açıklanmıştır.
Uygulamanızda FID oluşturan tüm hizmetleri devre dışı bırakmadığınız sürece FIS birkaç gün içinde yeni bir kimlik oluşturur. Firebase, yeni oluşturulan kimliği yeni bir Firebase yükleme olarak değerlendirir ve önceki kimlik veya verilerle hiçbir şekilde ilişkilendirmez.
İstemci API çağrısıyla FID silme
Firebase hizmetleri tarafından oluşturulan FID'leri silmek için Firebase Installations SDK'sından uygun yöntemi çağırın:
Swift
do { try await Installations.installations().delete() print("Installation deleted"); } catch { print("Error deleting installation: \(error)") }
Objective-C
[[FIRInstallations installations] deleteWithCompletion:^(NSError *error) { if (error != nil) { NSLog(@"Error deleting Installation %@", error); return; } NSLog(@"Installation deleted"); }];
Java
FirebaseInstallations.getInstance().delete() .addOnCompleteListener(new OnCompleteListener<Void>() { @Override public void onComplete(@NonNull Task<Void> task) { if (task.isSuccessful()) { Log.d("Installations", "Installation deleted"); } else { Log.e("Installations", "Unable to delete Installation"); } } });
Kotlin
FirebaseInstallations.getInstance().delete().addOnCompleteListener { task -> if (task.isComplete) { Log.d("Installations", "Installation deleted") } else { Log.e("Installations", "Unable to delete Installation") } }
JavaScript
await firebase.installations().delete();
Dart
await FirebaseInstallations.instance.delete();
Sunucu API çağrısıyla FID silme
Sunucu API çağrısıyla bir FID'yi silmek için Firebase Admin SDK'sını sunucunuza ekleyin (henüz eklemediyseniz).
SDK eklendikten sonra, tercih ettiğiniz dildeki silme işlevine yapılan bir çağrı aracılığıyla FID'leri silin (Not: Node.js hariç, bu yöntemler örnek kimliği adlandırmasını yansıtır). Ancak bunların tümü, mevcut herhangi bir Firebase SDK'sı ile çağrıldığında FID'yi siler.
Node.js
// An FIDsent from a client service SDK
const idToDelete = 'eyJhbGciOiJFUzI1N_iIs5';
admin.installations().deleteInstallation(idToDelete);
Java
// An FID sent from a client service SDK
String idToDelete = "eyJhbGciOiJFUzI1N_iIs5";
FirebaseInstanceId.getInstance().deleteInstanceIdAsync(idToDelete).get();
Python
from firebase_admin import instance_id
# An FID sent from a client service SDK
id_to_delete = 'eyJhbGciOiJFUzI1N_iIs5'
instance_id.delete_instance_id(id_to_delete)
Go
client, err := app.InstanceId(ctx)
if err != nil {
log.Fatalln("error initializing client", err)
}
iidToDelete := "eyJhbGciOiJFUzI1N_iIs5"
if err := client.DeleteInstanceId(ctx, iidToDelete); err != nil {
log.Fatalln("error deleting FID", err)
}
Bir Firebase yükleme kimliğini sunucu API çağrısıyla sildiğinizde Firebase hizmetleri, bu yükleme kimliğiyle ilişkili verileri silme işlemine başlar, 1-2 gün içinde bu kimlik için yeni veri kabul etmeyi durdurur ve ardından istemci uygulamasına kimliğin silindiğini bildirir. Firebase, istemci uygulamasına bildirim gönderene kadar uygulamanın bazı hizmetleri kimliği hedeflemeye devam edebilir. Örneğin, bir Firebase yüklemesi birkaç saat boyunca FCM bildirimleri almaya devam edebilir.
Mevcut Firebase yükleme kimliğini silmek ve Firebase hizmetlerini yeni, alakasız bir kimlikle hemen kullanmak istiyorsanız silme işlemini gerçekleştirmek için istemci API'sini kullanın.
İstemci tanımlayıcılarını alma
Uygulamanızın belirli yüklemelerini tanımlamanız gerekiyorsa Firebase yükleme kimliğini alarak bunu yapabilirsiniz. Örneğin, BigQuery'ye aktarma için uygulama yüklemeleri segmentleri oluşturmak veya Firebase In-App Messaging geliştirme sırasında test yapmak üzere ilgili Firebase yükleme kimliklerini kullanarak doğru cihazları tanımlayabilir ve hedefleyebilirsiniz.
Firebase kurulum kimliğini almak için:
Swift
do { let id = try await Installations.installations().installationID() print("Installation ID: \(id)") } catch { print("Error fetching id: \(error)") }
Objective-C
[[FIRInstallations installations] installationIDWithCompletion:^(NSString *identifier, NSError *error) { if (error != nil) { NSLog(@"Error fetching Installation ID %@", error); return; } NSLog(@"Installation ID: %@", identifier); }];
Java
FirebaseInstallations.getInstance().getId() .addOnCompleteListener(new OnCompleteListener<String>() { @Override public void onComplete(@NonNull Task<String> task) { if (task.isSuccessful()) { Log.d("Installations", "Installation ID: " + task.getResult()); } else { Log.e("Installations", "Unable to get Installation ID"); } } });
Kotlin
FirebaseInstallations.getInstance().id.addOnCompleteListener { task -> if (task.isSuccessful) { Log.d("Installations", "Installation ID: " + task.result) } else { Log.e("Installations", "Unable to get Installation ID") } }
JavaScript
const installationId = await firebase.installations().getId(); console.log(installationId);
Dart
String id = await FirebaseInstallations.instance.getId();
Yükleme yetkilendirme jetonlarını alma
Firebase hizmetleri, FIS'ten alınan kimlik doğrulama jetonlarıyla Firebase yüklemelerinin kimliğini doğrulayabilir. Örneğin, Remote Config için A/B testleri tasarlarken hedefli bir test cihazını yükleme kimlik doğrulama jetonu kullanarak doğrulayabilirsiniz.
Yükleme kimlik doğrulama jetonu, yüklemeyle ilgili aşağıdaki bilgileri içeren, kısa ömürlü bir taşıyıcı jetondur:
- Firebase kurulum kimliği
- İlişkili proje (
projectNumber) - İlişkili Firebase uygulama kimliği (
appId) - Jetonun son kullanma tarihi
Yükleme kimlik doğrulama jetonu iptal edilemez ve son kullanma tarihine kadar geçerli kalır. Varsayılan jeton ömrü bir haftadır.
Yükleme yetkilendirme jetonu almak için:
Swift
do { let result = try await Installations.installations() .authTokenForcingRefresh(true) print("Installation auth token: \(result.authToken)") } catch { print("Error fetching token: \(error)") }
Objective-C
[[FIRInstallations installations] authTokenForcingRefresh:true completion:^(FIRInstallationsAuthTokenResult *result, NSError *error) { if (error != nil) { NSLog(@"Error fetching Installation token %@", error); return; } NSLog(@"Installation auth token: %@", [result authToken]); }];
Java
FirebaseInstallations.getInstance().getToken(/* forceRefresh */true) .addOnCompleteListener(new OnCompleteListener<InstallationTokenResult>() { @Override public void onComplete(@NonNull Task<InstallationTokenResult> task) { if (task.isSuccessful() && task.getResult() != null) { Log.d("Installations", "Installation auth token: " + task.getResult().getToken()); } else { Log.e("Installations", "Unable to get Installation auth token"); } } });
Kotlin
val forceRefresh = true FirebaseInstallations.getInstance().getToken(forceRefresh) .addOnCompleteListener { task -> if (task.isSuccessful) { Log.d("Installations", "Installation auth token: " + task.result?.token) } else { Log.e("Installations", "Unable to get Installation auth token") } }
JavaScript
const installationToken = await firebase.installations() .getToken(/* forceRefresh */ true); console.log(installationToken);
Dart
String token = await FirebaseInstallations.instance.getToken();
Firebase kurulum kimliği yaşam döngüsünü izleme
Bir uygulamanın normal çalışması sırasında Firebase yükleme kimlikleri (FID'ler) özel izleme gerektirmez. Ancak FID'leri açıkça alan ve kullanan uygulamaların, FID'nin silinme veya döndürülme olasılığını izlemek için mantık eklemesi gerekir. FID'lerin silinebileceği veya döndürülebileceği bazı durumlar şunlardır:
- Uygulamanın kaldırılması veya yeniden yüklenmesi (ör. son kullanıcı yeni bir cihaza yüklediğinde)
- Son kullanıcı, uygulamanın veya cihazın önbelleğini temizler.
- FID silme işlemi, arka uçta uygulama etkinliği olmaması nedeniyle tetiklenir (şu anda bu işlem için eşik, 270 gün boyunca etkinlik olmamasıdır).
Uygulamalar bu tür durumlarda FID döndürme veya silme işlemiyle karşılaştığında onlara yeni bir FID atanır. Ayrıca, silinen bir FID ile ilişkili yükleme kimlik doğrulama jetonu, kendi olgunluğundan bağımsız olarak silinir ve yeni bir yükleme kimlik doğrulama jetonuyla değiştirilir.
Uygulamalar bu değişiklikleri izleyebilir ve buna göre yanıt verebilir.
FID döndürmeyi izlemek için:
Swift
installationIDObserver = NotificationCenter.default.addObserver( forName: .InstallationIDDidChange, object: nil, queue: nil ) { (notification) in // Fetch new Installation ID Task { await self.fetchInstallationToken() } }
Objective-C
__weak __auto_type weakSelf = self; self.installationIDObserver = [[NSNotificationCenter defaultCenter] addObserverForName: FIRInstallationIDDidChangeNotification object:nil queue:nil usingBlock:^(NSNotification * _Nonnull notification) { // Fetch new Installation ID [weakSelf fetchInstallationsID]; }];
Yeni bir FID atandığında varsayılan NSNotificationCenter'a NSNotificationName.InstallationIDDidChange adlı bir NSNotification gönderilir.
Android
Kotlin ve Java istemcileri, yeni FID'yi almak için başarısız olan çağrılara yanıt vermek üzere yeniden deneme mantığı eklemelidir.
JavaScript
Web uygulamaları onIdChange kancasına abone olabilir.
Yeni bir FID oluşturulduğunda, abone olunan geri çağırma tetiklenir:
await firebase.installations().onIdChange((newId) => { console.log(newId); // TODO: Handle new installation ID. });
Dart
FirebaseInstallations.instance.onIdChange.listen((token) {
print('FID token: $token');
});
Örnek kimliğinden Firebase yüklemelerine geçiş
Firebase yüklemeleri kullanıma sunulmadan önce Firebase, uygulama yüklemelerinin tanımlayıcıları için Instance ID SDK'sını kullanıyordu. Firebase yüklemeleri, güvenilirlik, performans ve güvenlik açısından Instance ID'ye kıyasla önemli avantajlar sunar. Örnek Kimliği SDK'sına bağlı Firebase uygulamaları, Firebase yüklemelerine taşınmalıdır.
Taşıma süreci, uygulamanıza bağlı olarak farklılık gösterir:
Instance ID API'lerini doğrudan çağırmayan uygulamalar, SDK sürümlerini güncelleyerek geçiş yapabilir. Çoğu Firebase uygulaması bu kategoriye girer.
Örnek Kimliği'ne açıkça API çağrıları yapan uygulamaların SDK sürümlerini güncellemesi ve Örnek Kimliği yöntemlerini kod değişiklikleri yaparak kendi Firebase yüklemeleri veya FCM eşdeğerleriyle değiştirmesi gerekir. Uygulamanız FCM kayıt jetonlarını almak için örnek kimliğini kullanıyorsa veya uygulama örneklerini hedeflemek ya da başka bir amaçla örnek kimliğini açıkça kullanıyorsa uygulama kodunuzu güncellemeniz gerekir.
FIS şu anda eski tanımlayıcı Firebase Instance ID ile geriye dönük olarak uyumludur. IID'yi silme şu Firebase SDK'ları ile veri silme isteğinde bulunmanın alternatif bir yöntemidir:
- iOS 6.14.0 ve önceki sürümler
- 27 Şubat 2020'den önceki Android SDK'ları
Bu nedenle, uygulamaların Firebase yüklemelerine taşınması gerekmez ancak bu işlem kesinlikle önerilir.
Firebase yüklemeleri için minimum SDK sürümlerine yükseltme
Instance ID'den Firebase yüklemelere geçiş yapmak için uygulamalarınızın aşağıdaki Firebase SDK'larının listelenen minimum sürüm numaralarını kullandığından emin olun:
| Firebase SDK'sı | Minimum Android sürümü | Minimum iOS sürümü |
| Firebase Cloud Messaging | v20.3.0 | v6.34.0 |
| Remote Config | v19.2.0 | v6.24.0 |
| Firebase için Google Analytics \ (Ölçüm SDK'sı) | v17.4.4 | v6.18.0 |
| Uygulama İçi Mesajlaşma | v19.0.7 | v6.24.0 |
| Performance Monitoring | v19.0.8 | v6.21.0 |
| Crashlytics | v17.2.1 | v6.23.0 |
| ML Kit | v22.1.2 | v6.28.0 |
Örnek Kimliği API'lerini açıkça çağıran kodu güncelleme
Android veya Apple uygulamanız doğrudan örnek kimliği SDK yöntemlerini kullanıyorsa bu kullanımı Firebase installations SDK'sında veya FCM SDK'sında aynı alternatiflerle değiştirebilirsiniz.
Tanımlayıcı alma
Örnek kimlikleri alma yöntemlerinin yerini yükleme kimliği alma yöntemleri aldı. Örneğin:
Önce
Swift
Messaging.messaging().token { token, error in if let error = error { print("Error fetching remote FCM registration token: \(error)") } else if let token = token { print("Remote instance ID token: \(token)") } }
Objective-C
[[FIRMessaging messaging] tokenWithCompletion:^(NSString * _Nullable token, NSError * _Nullable error) { if (error != nil) { NSLog(@"Error fetching the remote FCM registration token: %@", error); } else { NSLog(@"Remote FCM registration token: %@", token); NSString* message = [NSString stringWithFormat:@"FCM registration token: %@", token]; // display message NSLog(@"%@", message); } }];
Java
FirebaseInstanceId.getInstance().getInstanceId() .addOnCompleteListener(new OnCompleteListener<InstanceIdResult>() { @Override public void onComplete(@NonNull Task<InstanceIdResult> task) { Log.d("IID_TOKEN", task.getResult().getToken()); } });
Kotlin
FirebaseInstanceId.getInstance().instanceId .addOnSuccessListener { result -> Log.d("IID_TOKEN", result.token) }
Sonra
Swift
do { let id = try await Installations.installations().installationID() print("Installation ID: \(id)") } catch { print("Error fetching id: \(error)") }
Objective-C
[[FIRInstallations installations] installationIDWithCompletion:^(NSString *identifier, NSError *error) { if (error != nil) { NSLog(@"Error fetching Installation ID %@", error); return; } NSLog(@"Installation ID: %@", identifier); }];
Java
FirebaseInstallations.getInstance().getId() .addOnCompleteListener(new OnCompleteListener<String>() { @Override public void onComplete(@NonNull Task<String> task) { if (task.isSuccessful()) { Log.d("Installations", "Installation ID: " + task.getResult()); } else { Log.e("Installations", "Unable to get Installation ID"); } } });
Kotlin
FirebaseInstallations.getInstance().id.addOnCompleteListener { task -> if (task.isSuccessful) { Log.d("Installations", "Installation ID: " + task.result) } else { Log.e("Installations", "Unable to get Installation ID") } }
Tanımlayıcı silme
Örnek kimliklerini silme yöntemlerinin yerini Firebase yükleme kimliklerini silme yöntemleri alıyor. Örneğin:
Önce
Swift
InstanceID.instanceID().deleteID { error in
if let error = error {
print("Error deleting instance ID: \(error)")
}
}
Objective-C
[FIRInstanceID instanceID] deleteIDWithHandler:^(NSError *error) {
if error != nil {
NSLog(@"Error deleting instance ID: %@", error);
}
}];
Android
FirebaseInstanceId.deleteInstanceId();
Sonra
Swift
func delete(completion: @escaping (Error?) -> Void)
Objective-C
- (void)deleteWithCompletion:(nonnull void (^)(NSError *_Nullable))completion;
Java
FirebaseInstallations.getInstance().delete() .addOnCompleteListener(new OnCompleteListener<Void>() { @Override public void onComplete(@NonNull Task<Void> task) { if (task.isSuccessful()) { Log.d("Installations", "Installation deleted"); } else { Log.e("Installations", "Unable to delete Installation"); } } });
Kotlin
FirebaseInstallations.getInstance().delete().addOnCompleteListener { task -> if (task.isComplete) { Log.d("Installations", "Installation deleted") } else { Log.e("Installations", "Unable to delete Installation") } }
FCM kayıt jetonunu alma
Firebase Installations'ın kullanıma sunulmasından önce FCM istemcileri, Instance ID'den kayıt jetonlarını alıyordu. FCM SDK'sı artık kayıt jetonunu almak için yöntemler sunuyor.
Önce
Java
FirebaseInstanceId.getInstance().getInstanceId() .addOnCompleteListener(new OnCompleteListener<InstanceIdResult>() { @Override public void onComplete(@NonNull Task<InstanceIdResult> task) { if (!task.isSuccessful()) { Log.w(TAG, "getInstanceId failed", task.getException()); return; } // Get new Instance ID token String token = task.getResult().getToken(); // Log and toast String msg = getString(R.string.msg_token_fmt, token); Log.d(TAG, msg); Toast.makeText(MainActivity.this, msg, Toast.LENGTH_SHORT).show(); } });
Kotlin
FirebaseInstanceId.getInstance().instanceId .addOnCompleteListener(OnCompleteListener { task -> if (!task.isSuccessful) { Log.w(TAG, "getInstanceId failed", task.exception) return@OnCompleteListener } // Get new Instance ID token val token = task.result?.token // Log and toast val msg = getString(R.string.msg_token_fmt, token) Log.d(TAG, msg) Toast.makeText(baseContext, msg, Toast.LENGTH_SHORT).show() })
Swift
InstanceID.instanceID().instanceID { result, error in if let error = error { print("Error fetching instance ID: \(error)") } else if let result = result { print("Instance ID token: \(result.token)") } }
Objective-C
[[FIRInstanceID instanceID] instanceIDWithHandler:^(FIRInstanceIDResult * _Nullable result, NSError * _Nullable error) { if (error != nil) { NSLog(@"Error fetching instance ID: %@", error); } else { NSLog(@"Instance ID token: %@", result.token); } }];
Sonra
Java
FirebaseMessaging.getInstance().getToken() .addOnCompleteListener(new OnCompleteListener<String>() { @Override public void onComplete(@NonNull Task<String> task) { if (!task.isSuccessful()) { Log.w(TAG, "Fetching FCM registration token failed", task.getException()); return; } // Get new FCM registration token String token = task.getResult(); // Log and toast String msg = getString(R.string.msg_token_fmt, token); Log.d(TAG, msg); Toast.makeText(MainActivity.this, msg, Toast.LENGTH_SHORT).show(); } });
Kotlin
FirebaseMessaging.getInstance().token.addOnCompleteListener(OnCompleteListener { task -> if (!task.isSuccessful) { Log.w(TAG, "Fetching FCM registration token failed", task.exception) return@OnCompleteListener } // Get new FCM registration token val token = task.result // Log and toast val msg = getString(R.string.msg_token_fmt, token) Log.d(TAG, msg) Toast.makeText(baseContext, msg, Toast.LENGTH_SHORT).show() })
Swift
Messaging.messaging().token { token, error in if let error = error { print("Error fetching remote FCM registration token: \(error)") } else if let token = token { print("Remote instance ID token: \(token)") } }
Objective-C
[[FIRMessaging messaging] tokenWithCompletion:^(NSString * _Nullable token, NSError * _Nullable error) { if (error != nil) { NSLog(@"Error fetching the remote FCM registration token: %@", error); } else { NSLog(@"Remote FCM registration token: %@", token); NSString* message = [NSString stringWithFormat:@"FCM registration token: %@", token]; // display message NSLog(@"%@", message); } }];