Bảo vệ các tài nguyên không phải Firebase bằng Kiểm tra ứng dụng

Bạn có thể bảo vệ các tài nguyên không phải Firebase của ứng dụng, chẳng hạn như phần phụ trợ tự lưu trữ, bằng Kiểm tra ứng dụng. Để làm như vậy, bạn sẽ cần thực hiện cả hai thao tác sau:

  • Sửa đổi ứng dụng khách của bạn để gửi mã thông báo Kiểm tra ứng dụng cùng với mỗi yêu cầu tới chương trình phụ trợ của bạn, như được mô tả trên trang này.
  • Sửa đổi chương trình phụ trợ của bạn để yêu cầu mã thông báo Kiểm tra ứng dụng hợp lệ với mọi yêu cầu, như được mô tả trong Xác minh mã thông báo Kiểm tra ứng dụng từ chương trình phụ trợ tùy chỉnh .

Trước khi bắt đầu

Thêm Kiểm tra ứng dụng vào ứng dụng của bạn, sử dụng các nhà cung cấp mặc định .

Gửi mã thông báo Kiểm tra ứng dụng với các yêu cầu phụ trợ

Để đảm bảo các yêu cầu phụ trợ của bạn bao gồm mã thông báo Kiểm tra ứng dụng hợp lệ, chưa hết hạn, hãy đặt trước mỗi yêu cầu bằng lệnh gọi getToken() . Thư viện Kiểm tra ứng dụng sẽ làm mới mã thông báo nếu cần.

Khi bạn có một mã thông báo hợp lệ, hãy gửi nó cùng với yêu cầu tới chương trình phụ trợ của bạn. Chi tiết cụ thể về cách bạn thực hiện điều này là tùy thuộc vào bạn, nhưng không gửi mã thông báo Kiểm tra ứng dụng như một phần của URL , bao gồm cả trong các tham số truy vấn, vì điều này khiến chúng dễ bị rò rỉ và đánh chặn ngẫu nhiên. Phương pháp được đề xuất là gửi mã thông báo trong tiêu đề HTTP tùy chỉnh.

Ví dụ:

void callApiExample() async {
    final appCheckToken = await FirebaseAppCheck.instance.getToken();
    if (appCheckToken != null) {
        final response = await http.get(
            Uri.parse("https://yourbackend.example.com/yourExampleEndpoint"),
            headers: {"X-Firebase-AppCheck": appCheckToken},
        );
    } else {
        // Error: couldn't get an App Check token.
    }
}