Check out what’s new from Firebase at Google I/O 2022. Learn more

Bắt đầu với Cấu hình từ xa Firebase

Bạn có thể sử dụng Cấu hình từ xa Firebase để xác định các thông số trong ứng dụng của mình và cập nhật giá trị của chúng trên đám mây, cho phép bạn sửa đổi giao diện và hành vi của ứng dụng mà không cần phân phối bản cập nhật ứng dụng. Hướng dẫn này hướng dẫn bạn qua các bước để bắt đầu và cung cấp một số mã mẫu, tất cả đều có sẵn để sao chép hoặc tải xuống từ kho lưu trữ GitHub của firebase / quickstart-ios .

Thêm cấu hình từ xa vào ứng dụng của bạn

  1. Cài đặt SDK Firebase cho các nền tảng của Apple.

  2. Tạo đối tượng Cấu hình từ xa singleton, như được hiển thị trong ví dụ sau:

    Nhanh

    remoteConfig = RemoteConfig.remoteConfig()
    let settings = RemoteConfigSettings()
    settings.minimumFetchInterval = 0
    remoteConfig.configSettings = settings

    Objective-C

    self.remoteConfig = [FIRRemoteConfig remoteConfig];
    FIRRemoteConfigSettings *remoteConfigSettings = [[FIRRemoteConfigSettings alloc] init];
    remoteConfigSettings.minimumFetchInterval = 0;
    self.remoteConfig.configSettings = remoteConfigSettings;

Đối tượng này được sử dụng để lưu trữ các giá trị thông số mặc định trong ứng dụng, tìm nạp các giá trị thông số cập nhật từ chương trình phụ trợ Cấu hình từ xa và kiểm soát thời điểm các giá trị đã tìm nạp được cung cấp cho ứng dụng của bạn.

Trong quá trình phát triển, bạn nên đặt khoảng thời gian tìm nạp tối thiểu tương đối thấp. Xem Throttling để biết thêm thông tin.

Đặt giá trị thông số mặc định trong ứng dụng

Bạn có thể đặt các giá trị thông số mặc định trong ứng dụng trong đối tượng Cấu hình từ xa để ứng dụng của bạn hoạt động như dự kiến ​​trước khi kết nối với phần phụ trợ Cấu hình từ xa và để các giá trị mặc định có sẵn nếu không có giá trị nào được đặt trong phần phụ trợ.

  1. Xác định một tập hợp các tên tham số và các giá trị tham số mặc định bằng cách sử dụng đối tượng NSDictionary hoặc tệp plist .

    Nếu bạn đã định cấu hình các giá trị tham số phụ trợ Cấu hình từ xa, bạn có thể tải xuống tệp plist được tạo bao gồm tất cả các giá trị mặc định và lưu nó vào dự án Xcode của bạn.

    NGHỈ NGƠI

    curl --compressed -D headers -H "Authorization: Bearer token -X GET https://firebaseremoteconfig.googleapis.com/v1/projects/my-project-id/remoteConfig:downloadDefaults?format=PLIST -o RemoteConfigDefaults.plist
    

    Bảng điều khiển Firebase

    1. Trong tab Tham số , mở Menu và chọn Tải xuống các giá trị mặc định .

    2. Khi được nhắc, hãy bật .plist cho iOS , sau đó nhấp vào Tải xuống tệp .

  2. Thêm các giá trị này vào đối tượng Cấu hình từ xa bằng setDefaults: Ví dụ sau đặt các giá trị mặc định trong ứng dụng từ một tệp plist:

    Nhanh

    remoteConfig.setDefaults(fromPlist: "RemoteConfigDefaults")

    Objective-C

    [self.remoteConfig setDefaultsFromPlistFileName:@"RemoteConfigDefaults"];

Nhận các giá trị thông số để sử dụng trong ứng dụng của bạn

Bây giờ bạn có thể nhận các giá trị tham số từ đối tượng Cấu hình từ xa. Nếu sau này bạn đặt các giá trị trong phần phụ trợ Cấu hình từ xa, hãy tìm nạp chúng, rồi kích hoạt chúng, những giá trị đó sẽ có sẵn cho ứng dụng của bạn. Nếu không, bạn nhận được các giá trị thông số trong ứng dụng được định cấu hình bằng setDefaults: Để nhận các giá trị này, hãy gọi phương thức configValueForKey: cung cấp khóa tham số làm đối số.

Đặt giá trị tham số

Sử dụng bảng điều khiển Firebase hoặc API phụ trợ Cấu hình từ xa , bạn có thể tạo các giá trị mặc định phụ trợ mới ghi đè các giá trị trong ứng dụng theo logic có điều kiện hoặc nhắm mục tiêu người dùng mong muốn của bạn. Phần này sẽ hướng dẫn bạn các bước trong bảng điều khiển Firebase để tạo các giá trị này.

  1. Trong bảng điều khiển Firebase , hãy mở dự án của bạn.
  2. Chọn Cấu hình từ xa từ menu để xem bảng điều khiển Cấu hình từ xa.
  3. Xác định các thông số có cùng tên với các thông số mà bạn đã xác định trong ứng dụng của mình. Đối với mỗi thông số, bạn có thể đặt giá trị mặc định (giá trị này cuối cùng sẽ ghi đè giá trị mặc định trong ứng dụng) và bạn cũng có thể đặt giá trị có điều kiện. Để tìm hiểu thêm, hãy xem Thông số và điều kiện cấu hình từ xa .

Tìm nạp và kích hoạt các giá trị

Để tìm nạp các giá trị tham số từ Cấu hình từ xa, hãy gọi phương fetchWithCompletionHandler: hoặc fetchWithExpirationDuration:completionHandler: Bất kỳ giá trị nào bạn đặt trên chương trình phụ trợ đều được tìm nạp và lưu vào bộ nhớ đệm trong đối tượng Cấu hình từ xa.

Đối với các trường hợp bạn muốn tìm nạp và kích hoạt các giá trị trong một lần gọi, hãy sử dụng fetchAndActivateWithCompletionHandler: .

Ví dụ này tìm nạp các giá trị từ phần phụ trợ Cấu hình từ xa (không phải các giá trị được lưu trong bộ nhớ cache) và các lệnh gọi activateWithCompletionHandler: để cung cấp chúng cho ứng dụng:

Nhanh

remoteConfig.fetch { (status, error) -> Void in
  if status == .success {
    print("Config fetched!")
    self.remoteConfig.activate { changed, error in
      // ...
    }
  } else {
    print("Config not fetched")
    print("Error: \(error?.localizedDescription ?? "No error available.")")
  }
  self.displayWelcome()
}

Objective-C

[self.remoteConfig fetchWithCompletionHandler:^(FIRRemoteConfigFetchStatus status, NSError *error) {
    if (status == FIRRemoteConfigFetchStatusSuccess) {
        NSLog(@"Config fetched!");
      [self.remoteConfig activateWithCompletion:^(BOOL changed, NSError * _Nullable error) {
        // ...
      }];
    } else {
        NSLog(@"Config not fetched");
        NSLog(@"Error %@", error.localizedDescription);
    }
    [self displayWelcome];
}];

Vì các giá trị thông số được cập nhật này ảnh hưởng đến hoạt động và giao diện của ứng dụng, bạn nên kích hoạt các giá trị được tìm nạp tại một thời điểm để đảm bảo trải nghiệm mượt mà cho người dùng của bạn, chẳng hạn như lần tiếp theo người dùng mở ứng dụng của bạn. Xem các chiến lược tải cấu hình từ xa để biết thêm thông tin và ví dụ.

Throttling

Nếu một ứng dụng tìm nạp quá nhiều lần trong một khoảng thời gian ngắn, các lệnh gọi tìm nạp sẽ bị chặn và SDK trả về FIRRemoteConfigFetchStatusThrottled . Trước phiên bản SDK 6.3.0, giới hạn là 5 yêu cầu tìm nạp trong cửa sổ 60 phút (các phiên bản mới hơn có nhiều giới hạn cho phép hơn).

Trong quá trình phát triển ứng dụng, bạn có thể muốn làm mới bộ nhớ cache thường xuyên (nhiều lần mỗi giờ) để cho phép bạn lặp lại nhanh chóng khi bạn phát triển và thử nghiệm ứng dụng của mình. Để phù hợp với việc lặp lại nhanh chóng trên một dự án với nhiều nhà phát triển, bạn có thể tạm thời thêm thuộc tính FIRRemoteConfigSettings với khoảng thời gian tìm nạp tối thiểu thấp ( MinimumFetchInterval ) trong ứng dụng của mình.

Khoảng thời gian tìm nạp sản xuất mặc định và được đề xuất cho Cấu hình từ xa là 12 giờ, có nghĩa là các cấu hình sẽ không được tìm nạp từ chương trình phụ trợ nhiều hơn một lần trong cửa sổ 12 giờ, bất kể có bao nhiêu lệnh gọi tìm nạp thực sự được thực hiện. Cụ thể, khoảng thời gian tìm nạp tối thiểu được xác định theo thứ tự sau:

  1. Tham số trong fetch(long)
  2. Tham số trong FIRRemoteConfigSettings.MinimumFetchInterval
  3. Giá trị mặc định của 12 giờ

Bước tiếp theo

Nếu bạn chưa có, hãy khám phá các trường hợp sử dụng Cấu hình từ xa và xem qua một số khái niệm chính và tài liệu chiến lược nâng cao, bao gồm: