Quản lý lượt cài đặt Firebase

Dịch vụ cài đặt Firebase (FIS) cung cấp Mã cài đặt Firebase (FID) cho mỗi phiên bản đã cài đặt của một ứng dụng Firebase. Mã cài đặt Firebase được sử dụng nội bộ bởi các Firebase này các dịch vụ:

Dịch vụ Firebase Chức năng cài đặt Firebase
Giải pháp gửi thông báo qua đám mây của Firebase

Giải pháp Gửi thông báo qua đám mây của Firebase sử dụng Mã cài đặt Firebase để nhắm mục tiêu các thiết bị nhằm gửi tin nhắn.

Firebase Crashlytics

Firebase Crashlytics xoay vòng cài đặt Crashlytics Mã nhận dạng duy nhất (UUID) dựa trên các thay đổi đối với Firebase của phiên bản ứng dụng mã cài đặt. Trong tương lai, mã cài đặt có thể được dùng để bật các tính năng cải thiện dịch vụ báo cáo sự cố và quản lý sự cố.

Tính năng gửi thông báo trong ứng dụng của Firebase

Tính năng Gửi thông báo trong ứng dụng của Firebase sử dụng Mã cài đặt Firebase để nhắm mục tiêu các thiết bị nhằm gửi tin nhắn.

Giám sát hiệu suất Firebase

Giám sát hiệu suất sử dụng mã cài đặt Firebase để tính toán số lượt cài đặt Firebase riêng biệt truy cập tài nguyên mạng, để đảm bảo rằng các mẫu truy cập ẩn danh đủ. Công cụ này cũng sử dụng Mã cài đặt Firebase với Cấu hình từ xa Firebase để quản lý tỷ lệ báo cáo sự kiện hiệu suất.

Cấu hình từ xa Firebase

Cấu hình từ xa sử dụng mã cài đặt Firebase để chọn cấu hình để trả lại cho thiết bị của người dùng cuối.

Firebase ML

Thông tin đăng nhập đã được gọi mã thông báo xác thực cài đặt mà Firebase ML sử dụng cho xác thực thiết bị khi tương tác với ứng dụng ví dụ: để phân phối mô hình nhà phát triển cho các phiên bản ứng dụng.

Bộ nhớ phân khúc người dùng Firebase

Bộ nhớ phân đoạn người dùng Firebase lưu trữ mã cài đặt Firebase cũng như các thuộc tính và phân đoạn có liên quan để cung cấp thông tin nhắm mục tiêu với các dịch vụ Firebase khác sử dụng chúng.

Thông thường, các dịch vụ của Firebase sử dụng dịch vụ cài đặt Firebase mà không cần yêu cầu nhà phát triển tương tác trực tiếp với FIS API. Tuy nhiên, có những trường hợp mà nhà phát triển ứng dụng có thể muốn gọi trực tiếp FIS API, chẳng hạn như:

  • Để xoá một bản cài đặt Firebase và dữ liệu liên kết với lượt cài đặt đó.
  • Để truy xuất giá trị nhận dạng (mã cài đặt Firebase) nhằm nhắm mục tiêu lượt cài đặt ứng dụng cụ thể.
  • Cách truy xuất mã thông báo xác thực việc cài đặt nhằm xác thực Firebase cài đặt.

Để bắt đầu gọi điện trực tiếp FIS API, hãy thêm SDK vào ứng dụng của bạn.

Thêm SDK cài đặt Firebase vào ứng dụng của bạn

iOS trở lên

  1. Thêm phần phụ thuộc cho các lượt cài đặt Firebase vào Podfile:
    pod 'FirebaseInstallations'
  2. Chạy pod install và mở tệp .xcworkspace đã tạo.
  3. Nhập mô-đun FirebaseCore trong UIApplicationDelegate cũng như bất kỳ tên nào khác Các mô-đun Firebase mà người được uỷ quyền sử dụng. Ví dụ: Cách sử dụng Cloud Firestore và Xác thực:

    SwiftUI

    import SwiftUI
    import FirebaseCore
    import FirebaseFirestore
    import FirebaseAuth
    // ...
          

    Swift

    import FirebaseCore
    import FirebaseFirestore
    import FirebaseAuth
    // ...
          

    Objective-C

    @import FirebaseCore;
    @import FirebaseFirestore;
    @import FirebaseAuth;
    // ...
          
  4. Định cấu hình một FirebaseApp thực thể dùng chung trong Phương thức application(_:didFinishLaunchingWithOptions:):

    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];
  5. Nếu đang sử dụng SwiftUI, bạn phải tạo một ứng dụng uỷ quyền và đính kèm nó đến cấu trúc App của bạn thông qua UIApplicationDelegateAdaptor hoặc NSApplicationDelegateAdaptor. Bạn cũng phải tắt tính năng uỷ quyền ứng dụng. Để hãy xem hướng dẫn về SwiftUI để biết thêm thông tin.

    SwiftUI

    @main
    struct YourApp: App {
      // register app delegate for Firebase setup
      @UIApplicationDelegateAdaptor(AppDelegate.self) var delegate
    
      var body: some Scene {
        WindowGroup {
          NavigationView {
            ContentView()
          }
        }
      }
    }
          

Android

Thêm phần phụ thuộc cho SDK Android cài đặt Firebase vào tệp Gradle mô-đun (cấp ứng dụng) (thường là app/build.gradle):

implementation 'com.google.firebase:firebase-installations:18.0.0'

JavaScript

Tuỳ thuộc vào cách ứng dụng web được lưu trữ, cấu hình của bạn có thể được xử lý tự động hoặc bạn có thể cần phải cập nhật Đối tượng cấu hình Firebase.

Ví dụ: nếu các phần phụ thuộc của bạn được thêm vào trongindex.html, hãy thêm thuộc tính trong thẻ <head> phần tử:

<script src="/__/firebase/10.12.3/firebase-installations.js"></script>

Flutter

  1. Trong thư mục gốc của dự án Flutter, hãy chạy lệnh sau để cài đặt trình bổ trợ cài đặt Firebase:

    flutter pub add firebase_app_installations
    
  2. Tạo lại dự án:

    flutter run
    
  3. Nhập trình bổ trợ cài đặt Firebase:

    import 'package:firebase_app_installations/firebase_app_installations.dart';
    

Xoá chế độ cài đặt Firebase

Dữ liệu liên kết với quá trình cài đặt Firebase thường không mang tính cá nhân xác định danh tính. Tuy nhiên, bạn nên cho phép người dùng quản lý và xoá dữ liệu này.

Mã cài đặt Firebase khác nhau cho mỗi lượt cài đặt ứng dụng; các ứng dụng khác nhau trên cùng một thiết bị có các chỉ số Mã cài đặt Firebase. Mã cài đặt Firebase xác định ứng dụng cài đặt và dữ liệu gắn liền với lượt cài đặt ứng dụng đó.

Khi bạn xoá mã cài đặt, dữ liệu liên kết với mã cài đặt đó mã cài đặt sẽ bị xoá khỏi hệ thống trực tiếp và hệ thống sao lưu của tất cả Các dịch vụ của Firebase sử dụng mã cài đặt Firebase để xác định lượt cài đặt trong vòng 180 ngày. Quy trình này được mô tả ở cấp độ cao trong tuyên bố về việc xoá và giữ lại dữ liệu.

Trừ phi bạn tắt tất cả các dịch vụ tạo FID trong FIS sẽ tạo một mã nhận dạng mới trong vòng vài ngày. Firebase coi mã nhận dạng mới tạo là một bản cài đặt Firebase mới, và không liên kết tài khoản đó với mã nhận dạng hoặc dữ liệu trước đó theo bất kỳ cách nào.

Xoá FID bằng lệnh gọi API ứng dụng

Cách xoá FID do các dịch vụ Firebase tạo: gọi phương thức thích hợp từ SDK cài đặt Firebase:

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+KTX

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();

Xoá FID bằng lệnh gọi API máy chủ

Cách xoá FID bằng API máy chủ hãy thêm SDK quản trị Firebase vào máy chủ của bạn nếu bạn chưa thêm.

Sau khi thêm SDK, hãy xoá FID thông qua lệnh gọi đến bằng ngôn ngữ bạn chọn (lưu ý: Ngoại trừ Node.js, các hàm này phản ánh cách đặt tên mã thực thể. Tuy nhiên, tất cả họ đều xoá FID khi được gọi bằng Firebase SDK hiện tại).

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)

Tiến hành

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)
}

Khi bạn xoá mã cài đặt Firebase bằng lệnh gọi API máy chủ, Firebase Dịch vụ sẽ bắt đầu quá trình xoá dữ liệu gắn với mã cài đặt đó, dừng chấp nhận dữ liệu mới cho mã nhận dạng đó trong khoảng thời gian 1-2 ngày, sau đó thông báo ứng dụng khách mà mã nhận dạng đã bị xoá. Cho đến khi Firebase thông báo cho ứng dụng khách, một số các dịch vụ của ứng dụng vẫn có thể nhắm mục tiêu mã này, ví dụ: Firebase bản cài đặt có thể tiếp tục nhận được thông báo FCM trong một vài ngày giờ.

Nếu bạn muốn xoá mã cài đặt Firebase hiện tại và sử dụng ngay Các dịch vụ của Firebase có mã nhận dạng mới, không liên quan, sử dụng API ứng dụng khách để xử lý việc xoá.

Truy xuất giá trị nhận dạng ứng dụng khách

Nếu có yêu cầu xác định các lượt cài đặt cụ thể của ứng dụng, bạn có thể làm như vậy bằng cách truy xuất mã cài đặt Firebase. Ví dụ: để tạo các phân đoạn lượt cài đặt ứng dụng để nhập BiqQuery hoặc để thực hiện thử nghiệm trong quá trình phát triển Giải pháp gửi thông báo trong ứng dụng của Firebase, bạn có thể xác định và nhắm mục tiêu đúng thiết bị bằng cách sử dụng mã cài đặt Firebase tương ứng.

Cách truy xuất mã cài đặt Firebase:

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+KTX

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();

Truy xuất mã thông báo xác thực việc cài đặt

Các dịch vụ của Firebase có thể xác thực các lượt cài đặt Firebase bằng mã thông báo xác thực truy xuất từ FIS. Ví dụ: khi thiết kế thử nghiệm A/B cho Cấu hình từ xa, bạn có thể xác thực một thiết bị thử nghiệm được nhắm mục tiêu bằng cách sử dụng mã thông báo xác thực cài đặt.

Mã thông báo xác thực quá trình cài đặt là một mã thông báo mang tính tồn tại trong thời gian ngắn ở định dạng mã thông báo web JSON (JWT) chứa thông tin sau cho một lượt cài đặt:

  • Mã cài đặt Firebase
  • Dự án đã liên kết (projectNumber)
  • Mã ứng dụng Firebase đã liên kết (appId)
  • Ngày hết hạn của mã thông báo

Không thể thu hồi mã thông báo xác thực cài đặt và mã này vẫn có hiệu lực cho đến ngày hết hạn của tài khoản. Thời gian tồn tại của mã thông báo mặc định là một tuần.

Cách truy xuất mã thông báo xác thực chế độ cài đặt:

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+KTX

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();

Theo dõi vòng đời mã cài đặt Firebase

Trong quá trình hoạt động bình thường của ứng dụng, mã cài đặt Firebase (FID) không yêu cầu giám sát đặc biệt. Tuy nhiên, những ứng dụng truy xuất và sử dụng FID rõ ràng nên thêm logic để theo dõi khả năng xoá hoặc xoay Độ trễ đầu vào đầu tiên. Sau đây là một số trường hợp mà FID có thể bị xoá hoặc xoay:

  • Gỡ cài đặt hoặc cài đặt lại ứng dụng, chẳng hạn như khi người dùng cuối cài đặt trên thiết bị mới.
  • Người dùng cuối xoá bộ nhớ đệm của ứng dụng hoặc thiết bị.
  • Quá trình xoá FID được kích hoạt trong phần phụ trợ do ứng dụng không hoạt động (hiện ngưỡng cho chỉ số này là 270 ngày không hoạt động).

Khi ứng dụng gặp phải tình trạng xoay hoặc bị xoá FID trong những ứng dụng này các loại trường hợp khác nhau, thì chúng sẽ được chỉ định FID mới. Ngoài ra, mã thông báo xác thực cài đặt được liên kết với FID đã xoá là bị xoá, bất kể mức độ hoàn thiện của chính nó và được thay thế bằng mã thông báo xác thực cài đặt.

Các ứng dụng có thể theo dõi những thay đổi này và phản hồi một cách phù hợp.

Cách giám sát chế độ xoay FID:

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];
}];

Một NSNotification có tên NSNotificationName.InstallationIDDidChange là đăng lên NSNotificationCenter mặc định bất cứ khi nào có Đã chỉ định FID (Độ trễ đầu vào đầu tiên).

Android

Ứng dụng Kotlin và Java nên thêm logic thử lại để phản hồi các lệnh gọi không thành công để truy xuất FID mới.

JavaScript

Các ứng dụng web có thể đăng ký hook onIdChange.

Bất cứ khi nào một FID mới được tạo, lệnh gọi lại đã đăng ký sẽ là đã kích hoạt:

await firebase.installations().onIdChange((newId) => {
  console.log(newId);
  // TODO: Handle new installation ID.
});

Dart

FirebaseInstallations.instance.onIdChange.listen((token) {
  print('FID token: $token');
});

Di chuyển từ mã phiên bản sang lượt cài đặt Firebase

Trước khi bắt đầu cài đặt Firebase, Firebase dựa vào SDK mã phiên bản cho giá trị nhận dạng lượt cài đặt ứng dụng. Lượt cài đặt Firebase mang lại nhiều lợi thế đáng kể so với mã thực thể về độ tin cậy, hiệu suất, và bảo mật. Các ứng dụng Firebase phụ thuộc vào SDK mã phiên bản nên di chuyển đến lượt cài đặt Firebase.

Quá trình di chuyển khác nhau tuỳ theo ứng dụng của bạn:

  • Những ứng dụng không gọi trực tiếp API mã phiên bản có thể di chuyển bằng cách cập nhật các phiên bản SDK. Hầu hết các ứng dụng Firebase đều thuộc danh mục này.

  • Những ứng dụng thực hiện lệnh gọi API một cách rõ ràng đến mã phiên bản phải cập nhật phiên bản SDK thay đổi mã để thay thế Mã phiên bản bằng các phương thức Lượt cài đặt Firebase hoặc FCM tương đương. Nếu ứng dụng của bạn sử dụng Mã phiên bản để truy xuất mã thông báo đăng ký FCM hoặc sử dụng rõ ràng Mã phiên bản để nhắm mục tiêu các phiên bản ứng dụng hoặc cho mục đích khác, bạn sẽ cần phải hãy cập nhật mã xử lý ứng dụng của mình.

Hiện tại, FIS tương thích ngược với mã phiên bản Firebase của giá trị nhận dạng cũ. Xoá IID là một phương thức thay thế để yêu cầu xoá dữ liệu bằng các SDK Firebase sau:

  • iOS 6.14.0 trở xuống
  • Các SDK Android trước ngày 27 tháng 2 năm 2020

Điều này có nghĩa là bạn không bắt buộc phải di chuyển các ứng dụng sang lượt cài đặt Firebase; tuy nhiên, bạn nên làm như vậy.

Nâng cấp lên các phiên bản SDK tối thiểu để cài đặt Firebase

Để di chuyển từ mã phiên bản sang lượt cài đặt Firebase, hãy đảm bảo rằng ứng dụng sử dụng ít nhất số phiên bản tối thiểu được liệt kê của Firebase SDK sau:

SDK Firebase Phiên bản Android tối thiểu Phiên bản iOS tối thiểu
Giải pháp gửi thông báo qua đám mây của Firebase Phiên bản 20.3.0 Phiên bản 6.34.0
Cấu hình từ xa Các phiên bản 19.2.0 Phiên bản 6.24.0
Google Analytics cho Firebase \ (SDK Đo lường) Phiên bản 17.4.4 Phiên bản 6.18.0
Gửi thông báo trong ứng dụng Các phiên bản 19.0.7 Phiên bản 6.24.0
Giám sát hiệu suất Phiên bản 19.0.8 Phiên bản 6.21.0
Crashlytics Phiên bản 17.2.1 Phiên bản 6.23.0
Bộ công cụ máy học Phiên bản 22.1.2 Phiên bản 6.28.0

Cập nhật mã gọi rõ ràng Instance ID API

Nếu ứng dụng Android hoặc Apple của bạn trực tiếp sử dụng các phương thức SDK mã phiên bản, bạn có thể thay thế cách sử dụng đó bằng các giải pháp thay thế tương tự trong lượt cài đặt Firebase SDK hoặc FCM SDK.

Truy xuất giá trị nhận dạng

Các phương thức để lấy mã thực thể sẽ được thay thế bằng các phương thức để thu thập lượt cài đặt Mã nhận dạng. Ví dụ:

Trước

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)")
    self.remoteFCMTokenMessage.text = "Remote FCM registration 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];
     self.remoteFCMTokenMessage.text = 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+KTX

FirebaseInstanceId.getInstance().instanceId
        .addOnSuccessListener { result ->
            Log.d("IID_TOKEN", result.token)
        }

Sau

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+KTX

FirebaseInstallations.getInstance().id.addOnCompleteListener { task ->
    if (task.isSuccessful) {
        Log.d("Installations", "Installation ID: " + task.result)
    } else {
        Log.e("Installations", "Unable to get Installation ID")
    }
}

Xoá giá trị nhận dạng

Các phương thức xoá mã phiên bản sẽ được thay thế bằng phương thức xoá Mã cài đặt Firebase. Ví dụ:

Trước

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();

Sau

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+KTX

FirebaseInstallations.getInstance().delete().addOnCompleteListener { task ->
    if (task.isComplete) {
        Log.d("Installations", "Installation deleted")
    } else {
        Log.e("Installations", "Unable to delete Installation")
    }
}

Truy xuất mã thông báo đăng ký FCM

Trước khi cài đặt Firebase, ứng dụng FCM đã truy xuất mã thông báo đăng ký từ Mã phiên bản. Giờ đây, SDK FCM cung cấp các phương thức để truy xuất mã thông báo đăng ký.

Trước

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+KTX

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

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)")
    self.remoteFCMTokenMessage.text = "Remote FCM registration 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];
     self.remoteFCMTokenMessage.text = message;
   }
 }];

Sau

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+KTX

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 FCM registration token: \(error)")
  } else if let token = token {
    print("FCM registration token: \(token)")
    self.fcmRegTokenMessage.text  = "Remote FCM registration token: \(token)"
  }
}

Objective-C

[[FIRMessaging messaging] tokenWithCompletion:^(NSString *token, NSError *error) {
  if (error != nil) {
    NSLog(@"Error getting FCM registration token: %@", error);
  } else {
    NSLog(@"FCM registration token: %@", token);
    self.fcmRegTokenMessage.text = token;
  }
}];