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 tham 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à hoạt động 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 sẽ hướng dẫn bạn các bước để bắt đầu và cung cấp một số mã mẫu.

Bước 1: Thêm Firebase và SDK cấu hình từ xa vào ứng dụng của bạn

  1. Cài đặt và khởi chạy SDK Firebase cho Flutter nếu bạn chưa làm như vậy.

  2. Đối với Cấu hình từ xa, cần có Google Analytics để nhắm mục tiêu có điều kiện các phiên bản ứng dụng tới thuộc tính người dùng và đối tượng. Đảm bảo rằng bạn bật Google Analytics trong dự án của mình.

  3. Từ thư mục gốc của dự án Flutter của bạn, hãy chạy lệnh sau để cài đặt plugin Cấu hình từ xa:

    flutter pub add firebase_remote_config
    

    Ngoài ra, trong quá trình thiết lập Cấu hình từ xa, bạn cần thêm SDK Firebase cho Google Analytics vào ứng dụng của mình:

    flutter pub add firebase_analytics
    
  4. Xây dựng lại dự án của bạn:

    flutter run
    
  5. Nếu bạn đang sử dụng Cấu hình từ xa trên macOS, hãy bật Chia sẻ chuỗi khóa trong Xcode.

Bước 2: Lấy đối tượng singleton Remote Config

Nhận một phiên bản đối tượng Cấu hình từ xa và đặt khoảng thời gian tìm nạp tối thiểu để cho phép làm mới thường xuyên:

final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
    fetchTimeout: const Duration(minutes: 1),
    minimumFetchInterval: const Duration(hours: 1),
));

Đối tượng singleton được sử dụng để lưu trữ các giá trị tham số mặc định trong ứng dụng, tìm nạp các giá trị tham số được cập nhật từ chương trình phụ trợ và kiểm soát thời điểm cung cấp các giá trị được tìm nạ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 Điều chỉnh để biết thêm thông tin.

Bước 3: Đặt giá trị tham 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ự định 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ợ.

await remoteConfig.setDefaults(const {
    "example_param_1": 42,
    "example_param_2": 3.14159,
    "example_param_3": true,
    "example_param_4": "Hello, world!",
});

Bước 4: 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ể nhận các giá trị tham số từ đối tượng Remote Config. Nếu bạn đặt các giá trị trong phần phụ trợ, 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 setDefaults() .

Để có được những giá trị này, hãy gọi phương thức được liệt kê bên dưới để ánh xạ tới loại dữ liệu mà ứng dụng của bạn mong đợi, cung cấp khóa tham số làm đối số:

  • getBool()
  • getDouble()
  • getInt()
  • getString()

Bước 5: Đặt giá trị tham số trong phần phụ trợ Cấu hình từ xa

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ía máy chủ 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 theo người dùng mà bạn mong muốn. Phần này mô tả 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 thông tin Cấu hình từ xa.
  3. 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 tham số, bạn có thể đặt giá trị mặc định (cuối cùng giá trị này sẽ ghi đè giá trị mặc định trong ứng dụng tương ứ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à thông số cấu hình từ xa .

Bước 6: Tìm nạp và kích hoạt các giá trị

  1. Để tìm nạp các giá trị tham số từ phần phụ trợ Cấu hình từ xa, hãy gọi phương thức fetch() . Mọi giá trị bạn đặt trong phần phụ trợ đều được tìm nạp và lưu trữ trong đối tượng Cấu hình từ xa.

  2. Để cung cấp các giá trị tham số được tìm nạp cho ứng dụng của bạn, hãy gọi phương thức activate() .

    Đối với trường hợp muốn tìm nạp và kích hoạt các giá trị trong một lệnh gọi, bạn có thể sử dụng yêu cầu fetchAndActivate() để tìm nạp các giá trị từ phần phụ trợ Cấu hình từ xa và cung cấp chúng cho ứng dụng:

    await remoteConfig.fetchAndActivate();
    

Vì các giá trị thông 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 tại thời điểm đảm bảo trải nghiệm mượt mà cho người dùng, 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ụ.

Bước 7: Nghe cập nhật theo thời gian thực

Sau khi tìm nạp các giá trị tham số, bạn có thể sử dụng Cấu hình từ xa theo thời gian thực để lắng nghe các bản cập nhật từ chương trình phụ trợ Cấu hình từ xa. Tín hiệu Cấu hình từ xa theo thời gian thực tới các thiết bị được kết nối khi có bản cập nhật và tự động tìm nạp các thay đổi sau khi bạn xuất bản phiên bản Cấu hình từ xa mới.

Lưu ý rằng Cấu hình từ xa thời gian thực không có sẵn cho Web.

  1. Trong ứng dụng của bạn, hãy sử dụng onConfigUpdated để bắt đầu lắng nghe các bản cập nhật và tự động tìm nạp mọi giá trị thông số mới.

     remoteConfig.onConfigUpdated.listen((event) async {
       await remoteConfig.activate();
    
       // Use the new config values here.
     });
    
  2. Lần tới khi bạn xuất bản phiên bản mới của Cấu hình từ xa, các thiết bị đang chạy ứng dụng của bạn và lắng nghe các thay đổi sẽ kích hoạt cấu hình mới.

Điều tiết

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ị hạn chế và giá trị thuộc tính lastFetchStatus của FirebaseRemoteConfig sẽ là RemoteConfigFetchStatus.throttle .

Khoảng thời gian tìm nạp tối thiểu mặc định cho Cấu hình từ xa là 12 giờ, 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 lần trong khoảng thời gian 12 giờ, bất kể thực tế có bao nhiêu lệnh gọi tìm nạp được thực hiện.

Trong quá trình phát triển ứng dụng, nếu không sử dụng Cấu hình từ xa theo thời gian thực (mà chúng tôi khuyên dùng), bạn có thể muốn tìm nạp và kích hoạt cấu hình rất thường xuyên (nhiều lần mỗi giờ) để cho phép bạn lặp lại nhanh chóng khi 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 có tối đa 10 nhà phát triển, bạn có thể tạm thời đặt khoảng thời gian tìm nạp tối thiểu thấp bằng setConfigSettings() .

final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
    fetchTimeout: const Duration(minutes: 1),
    minimumFetchInterval: const Duration(minutes: 5),
));

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 xét một số khái niệm chính và tài liệu chiến lược nâng cao, bao gồm: