Menggunakan App Check untuk mengamankan kunci API Anda
Firebase App Check memberikan perlindungan untuk panggilan dari aplikasi Anda ke Google Maps Platform dengan memblokir traffic yang berasal dari sumber selain aplikasi yang sah. Hal ini dilakukan dengan memeriksa token dari penyedia pengesahan seperti Play Integrity. Mengintegrasikan aplikasi Anda dengan App Check membantu melindungi dari permintaan berbahaya, sehingga Anda tidak ditagih untuk panggilan API yang tidak sah.
Apakah App Check cocok untuk saya?
App Check direkomendasikan dalam sebagian besar kasus, tetapi App Check tidak diperlukan atau tidak didukung dalam kasus berikut:
- Anda menggunakan Places SDK asli. App Check hanya didukung untuk Places SDK (Baru).
- Aplikasi pribadi atau eksperimental. Jika aplikasi Anda tidak dapat diakses secara publik, App Check tidak diperlukan.
- Jika aplikasi Anda hanya digunakan server-ke-server, App Check tidak diperlukan. Namun, jika server yang berkomunikasi dengan GMP digunakan oleh klien publik (seperti aplikasi seluler), pertimbangkan untuk menggunakan App Check untuk melindungi server tersebut, bukan GMP.
- Penyedia pengesahan yang direkomendasikan App Check tidak akan berfungsi di perangkat yang dianggap terkompromi atau tidak tepercaya oleh penyedia pengesahan Anda. Jika Anda perlu mendukung perangkat tersebut, Anda dapat men-deploy layanan pengesahan kustom. Untuk mengetahui informasi selengkapnya, lihat petunjuk.
Ringkasan langkah-langkah penerapan
Secara umum, berikut langkah-langkah yang akan Anda ikuti untuk mengintegrasikan aplikasi dengan App Check:
- Tambahkan Firebase ke aplikasi Anda.
- Tambahkan dan lakukan inisialisasi library App Check.
- Tambahkan penyedia token.
- Aktifkan proses debug.
- Pantau permintaan aplikasi Anda dan tentukan penegakan.
Setelah terintegrasi dengan App Check, Anda dapat melihat metrik traffic backend di Firebase console. Metrik ini memberikan perincian permintaan berdasarkan apakah permintaan tersebut disertai dengan token App Check yang valid. Lihat dokumentasi Firebase App Check untuk mengetahui informasi selengkapnya.
Jika Anda yakin bahwa sebagian besar permintaan berasal dari sumber yang sah dan pengguna telah mengupdate ke aplikasi versi terbaru yang menyertakan penerapan App Check, Anda dapat mengaktifkan penegakan. Setelah penerapan diaktifkan, App Check akan menolak semua traffic tanpa token App Check yang valid.
Pertimbangan saat merencanakan integrasi App Check
Berikut beberapa hal yang perlu dipertimbangkan saat Anda merencanakan integrasi:
Penyedia pengesahan yang kami rekomendasikan, Play Integrity, memiliki batas panggilan harian untuk tingkat penggunaan API Standarnya. Untuk mengetahui informasi selengkapnya tentang batas panggilan, lihat halaman Penyiapan di dokumentasi developer Google Play Integrity.
Anda juga dapat memilih untuk menggunakan penyedia pengesahan kustom, meskipun ini adalah kasus penggunaan lanjutan. Untuk mengetahui informasi selengkapnya, lihat Menerapkan penyedia App Check kustom.
-
Pengguna aplikasi Anda akan mengalami beberapa latensi saat aplikasi dimulai. Namun, setelahnya, pengesahan ulang berkala akan terjadi di latar belakang dan pengguna tidak akan lagi mengalami latensi. Jumlah latensi yang tepat saat startup bergantung pada penyedia pengesahan yang Anda pilih.
Jumlah waktu validitas token App Check (time to live, atau TTL) menentukan frekuensi pengesahan ulang. Durasi ini dapat dikonfigurasi di Firebase console. Pengesahan ulang terjadi saat sekitar setengah TTL telah berlalu. Untuk mengetahui informasi selengkapnya, lihat dokumen Firebase untuk penyedia pengesahan Anda.
Mengintegrasikan aplikasi Anda dengan App Check
Prasyarat dan persyaratan
- Aplikasi dengan Places SDK versi 4.1 atau yang lebih baru terintegrasi.
- Sidik jari SHA-256 untuk aplikasi Anda.
- Nama paket aplikasi Anda.
- Anda harus menjadi pemilik aplikasi di Konsol Cloud.
- Anda akan memerlukan project ID aplikasi dari Konsol Cloud
Langkah 1: Menambahkan Firebase ke aplikasi Anda
Ikuti petunjuk dalam dokumentasi developer Firebase untuk menambahkan Firebase ke aplikasi Anda.
Langkah 2: Tambahkan library App Check dan inisialisasi App Check
Untuk mengetahui informasi tentang cara menggunakan Play Integrity, penyedia pengesahan default, lihat Mulai menggunakan App Check dengan Play Integrity di Android.
- Jika belum, integrasikan Places SDK ke dalam aplikasi Anda.
Selanjutnya, lakukan inisialisasi App Check dan Places client.
// Initialize App Check FirebaseApp.initializeApp(/* context= */ this); FirebaseAppCheck firebaseAppCheck = FirebaseAppCheck.getInstance(); firebaseAppCheck.installAppCheckProviderFactory( PlayIntegrityAppCheckProviderFactory.getInstance()); // Initialize Places SDK Places.initializeWithNewPlacesApiEnabled(context, API_KEY); PlacesClient client = Places.createClient(context);.
Langkah 3: Tambahkan penyedia token
Setelah menginisialisasi Places API, panggil setPlacesAppCheckTokenProvider()
untuk menetapkan PlacesAppCheckTokenProvider
.
Places.initializeWithNewPlacesApiEnabled(context, API_KEY); Places.setPlacesAppCheckTokenProvider(new TokenProvider()); PlacesClient client = Places.createClient(context);.
Berikut adalah contoh penerapan antarmuka pengambilan token:
/** Sample client implementation of App Check token fetcher interface. */ static class TokenProvider implements PlacesAppCheckTokenProvider { @Override public ListenableFuture<String> fetchAppCheckToken() { SettableFuture<String> future = SettableFuture.create(); FirebaseAppCheck.getInstance() .getAppCheckToken(false) .addOnSuccessListener( appCheckToken -> { future.set(appCheckToken.getToken()); }) .addOnFailureListener( ex -> { future.setException(ex); }); return future; } }
Langkah 4: Aktifkan proses debug (opsional)
Jika ingin mengembangkan dan menguji aplikasi secara lokal, atau menjalankannya di lingkungan continuous integration (CI), Anda dapat membuat build debug aplikasi yang menggunakan secret debug untuk mendapatkan token App Check yang valid. Hal ini memungkinkan Anda menghindari penggunaan penyedia pengesahan nyata dalam build debug.
Untuk menjalankan aplikasi di emulator atau perangkat pengujian:
- Tambahkan library App Check ke file
build.gradle
Anda. - Konfigurasi App Check untuk menggunakan factory penyedia debug di build debug Anda.
- Luncurkan aplikasi, yang akan membuat token debug lokal. Tambahkan token ini ke Firebase console.
- Untuk mengetahui informasi dan petunjuk selengkapnya, lihat dokumentasi App Check.
Untuk menjalankan aplikasi Anda di lingkungan CI:
- Buat token debug di Firebase console dan tambahkan ke penyimpanan kunci aman sistem CI Anda.
- Tambahkan library App Check ke file
build.gradle
Anda. - Konfigurasi varian build CI Anda untuk menggunakan token debug.
- Gabungkan kode di class pengujian yang memerlukan token App Check dengan
DebugAppCheckTestHelper
. - Untuk mengetahui informasi dan petunjuk selengkapnya, lihat dokumentasi App Check.
Langkah 5: Pantau permintaan aplikasi Anda dan tentukan penegakan
Sebelum memulai penerapan, Anda harus memastikan bahwa pengguna sah aplikasi Anda tidak akan terganggu. Untuk melakukannya, buka layar metrik App Check untuk melihat persentase traffic aplikasi Anda yang terverifikasi, tidak berlaku, atau tidak sah. Setelah melihat bahwa sebagian besar traffic Anda diverifikasi, Anda dapat mengaktifkan penerapan.
Lihat dokumentasi Firebase App Check untuk mengetahui informasi dan petunjuk selengkapnya.