Bạn có thể sử dụng Cấu hình từ xa Firebase để xác định các tham số trong ứng dụng của mình và cập nhật giá trị của chúng trong đá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ữ firebase/quickstart-ios GitHub.
Bước 1: Thêm Remote Config vào ứng dụng của bạn
Cài đặt SDK Firebase cho nền tảng Apple.
Tạo đối tượng Cấu hình Từ xa đơn lẻ, như minh họa trong ví dụ sau:
Nhanh
remoteConfig = RemoteConfig.remoteConfig() let settings = RemoteConfigSettings() settings.minimumFetchInterval = 0 remoteConfig.configSettings = settings
Mục tiêu-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 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.
Bước 2: Đặt giá trị thông số mặc định trong ứng dụng
Bạn có thể đặt các giá trị tham 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 khả dụng nếu không có giá trị nào được đặt trong phần phụ trợ.
Xác định một tập hợp tên tham số và 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 tệp đó 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 căn cứ hỏa lực
Trong tab Tham số , mở Menu và chọn Tải xuống các giá trị mặc định .
Khi được nhắc, hãy bật .plist cho iOS , sau đó nhấp vào Tải xuống tệp .
Thêm các giá trị này vào đối tượng Cấu hình từ xa bằng cách sử dụng
setDefaults:
. Ví dụ sau đặt giá trị mặc định trong ứng dụng từ tệp plist:Nhanh
remoteConfig.setDefaults(fromPlist: "RemoteConfigDefaults")
Mục tiêu-C
[self.remoteConfig setDefaultsFromPlistFileName:@"RemoteConfigDefaults"];
Bước 3: Nhận các giá trị tham số để sử dụng trong ứng dụng của bạn
Bây giờ bạn có thể lấy 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, thì những giá trị đó sẽ có sẵn cho ứng dụng của bạn. Nếu không, bạn sẽ nhận được các giá trị thông số trong ứng dụng được định cấu hình bằng cách sử dụ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ố.
Bước 4: Đặt giá trị tham số
Bằng cách 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 điều kiện mong muốn của bạn hoặc nhắm mục tiêu người dùng. Phần này hướng dẫn bạn qua các bước của bảng điều khiển Firebase để tạo các giá trị này.
- Trong bảng điều khiển Firebase , hãy mở dự án của bạn.
- Chọn Cấu hình từ xa từ menu để xem bảng điều khiển Cấu hình từ xa.
- Xác định các tham số có cùng tên với các tham 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 Điều kiện và Tham số Cấu hình Từ xa .
Bước 5: Tìm nạp và kích hoạt các giá trị
Để tìm nạp các giá trị tham số từ Remote Config, hãy gọi phương thức 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ớ cache trong đối tượng Cấu hình từ xa.
Đối với 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ệnh gọi, hãy sử dụng fetchAndActivateWithCompletionHandler:
.
Ví dụ này tìm nạp các giá trị từ phụ trợ Cấu hình từ xa (không phải giá trị được lưu trong bộ nhớ cache) và 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() }
Mục tiêu-C
[self.remoteConfig fetchWithCompletionHandler:^(FIRRemoteConfigFetchStatus status, NSError *error) { if (status == FIRRemoteConfigFetchStatusSuccess) { NSLog(@"Config fetched!"); [self.remoteConfig activateWithCompletion:^(BOOL changed, NSError * _Nullable error) { if (error != nil) { NSLog(@"Activate error: %@", error.localizedDescription); } else { dispatch_async(dispatch_get_main_queue(), ^{ [self displayWelcome]; }); } }]; } else { NSLog(@"Config not fetched"); NSLog(@"Error %@", error.localizedDescription); } }];
Vì các giá trị tham số được cập nhật này ảnh hưởng đến hành vi và giao diện của ứng dụng, nên bạn nên kích hoạt các giá trị được tìm nạp vào 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 Chiến lược tải cấu hình từ xa để biết thêm thông tin và ví dụ.
tiết lưu
If an app fetches too many times in a short time period, fetch calls are throttled and the SDK returns FIRRemoteConfigFetchStatusThrottled
. Before SDK version 6.3.0, the limit was 5 fetch requests in a 60 minute window (newer versions have more permissive limits).
During app development, you might want to refresh the cache very frequently (many times per hour) to let you rapidly iterate as you develop and test your app. To accommodate rapid iteration on a project with numerous developers, you can temporarily add a FIRRemoteConfigSettings
property with a low minimum fetch interval ( MinimumFetchInterval
) in your app.
The default and recommended production fetch interval for Remote Config is 12 hours, which means that configs won't be fetched from the backend more than once in a 12 hour window, regardless of how many fetch calls are actually made. Specifically, the minimum fetch interval is determined in this following order:
- The parameter in
fetch(long)
- The parameter in
FIRRemoteConfigSettings.MinimumFetchInterval
- The default value of 12 hours
Bước tiếp theo
If you haven't already, explore the Remote Config use cases , and take a look at some of the key concepts and advanced strategies documentation, including: