Utiliser App Check pour sécuriser votre clé API
Firebase App Check protège les appels de votre application vers Google Maps Platform en bloquant le trafic provenant d'autres sources que les applications légitimes. Pour ce faire, elle recherche un jeton provenant d'un fournisseur d'attestation tel que Play Integrity. Intégrer App Check à vos applications vous permet de vous protéger contre les requêtes malveillantes, et vous n'êtes donc pas facturé pour les appels d'API non autorisés.
App Check est-il adapté à mes besoins ?
Dans la plupart des cas, App Check est recommandé. Toutefois, il n'est pas nécessaire ou n'est pas compatible dans les cas suivants:
- Vous utilisez le SDK Places d'origine. App Check n'est compatible qu'avec le SDK Places (nouveau).
- Applications privées ou expérimentales. Si votre application n'est pas accessible au public, l'App Check n'est pas nécessaire.
- Si votre application n'est utilisée que de serveur à serveur, la vérification de l'application n'est pas nécessaire. Toutefois, si le serveur qui communique avec GMP est utilisé par des clients publics (tels que des applications mobiles), envisagez d'utiliser App Check pour protéger ce serveur au lieu de GMP.
- Les fournisseurs d'attestation recommandés par App Check ne fonctionnent pas sur les appareils considérés comme compromis ou non fiables par votre fournisseur d'attestation. Si vous devez prendre en charge ces appareils, vous pouvez déployer un service d'attestation personnalisé. Pour en savoir plus, consultez les instructions.
Présentation des étapes d'implémentation
Voici les étapes à suivre pour intégrer votre application à App Check:
- Ajoutez Firebase à votre application.
- Ajoutez et initialisez la bibliothèque App Check.
- Ajoutez le fournisseur de jetons.
- Activez le débogage.
- Surveillez les requêtes de votre application et décidez de la mise en œuvre.
Une fois l'intégration à App Check effectuée, vous pourrez consulter les métriques de trafic du backend dans la console Firebase. Ces métriques fournissent une répartition des requêtes selon qu'elles sont accompagnées d'un jeton App Check valide ou non. Pour en savoir plus, consultez la documentation Firebase App Check.
Lorsque vous êtes sûr que la plupart des requêtes proviennent de sources légitimes et que les utilisateurs ont mis à jour la dernière version de votre application incluant votre implémentation d'App Check, vous pouvez activer l'application. Une fois l'application activée, App Check refusera tout trafic sans jeton App Check valide.
Éléments à prendre en compte lors de la planification d'une intégration d'App Check
Voici quelques éléments à prendre en compte lorsque vous planifiez votre intégration:
Le fournisseur d'attestation que nous vous recommandons, Play Integrity, impose une limite d'appels quotidiens pour son niveau d'utilisation de l'API standard. Pour en savoir plus sur les limites d'appels, consultez la page Configuration de la documentation destinée aux développeurs Google Play Integrity.
Vous pouvez également choisir d'utiliser un fournisseur d'attestation personnalisé, bien que ce soit un cas d'utilisation avancé. Pour en savoir plus, consultez Implémenter un fournisseur App Check personnalisé.
-
Les utilisateurs de votre application subiront une latence au démarrage. Toutefois, par la suite, toute réattestation périodique se produira en arrière-plan, et les utilisateurs ne devraient plus subir de latence. La latence exacte au démarrage dépend du fournisseur d'attestation que vous choisissez.
La durée de validité du jeton App Check (la durée de vie ou TTL) détermine la fréquence des réattestations. Cette durée peut être configurée dans la console Firebase. La réattestation se produit lorsque la moitié environ de la durée de validité du TTL s'est écoulée. Pour en savoir plus, consultez la documentation Firebase sur votre fournisseur d'attestation.
Intégrer votre application à App Check
Prérequis et exigences
- Une application avec le SDK Places version 4.1 ou ultérieure intégré.
- Empreinte SHA-256 de votre application.
- Nom du package de votre application.
- Vous devez être le propriétaire de l'application dans Cloud Console.
- Vous aurez besoin de l'ID de projet de l'application dans la console Cloud.
Étape 1: Ajoutez Firebase à votre application
Suivez les instructions de la documentation destinée aux développeurs Firebase pour ajouter Firebase à votre application.
Étape 2: Ajoutez la bibliothèque App Check et initialisez-la
Pour en savoir plus sur l'utilisation de Play Integrity, le fournisseur d'attestation par défaut, consultez Premiers pas avec App Check avec Play Integrity sur Android.
- Si vous ne l'avez pas déjà fait, intégrez le SDK Places à votre application.
Ensuite, initialisez App Check et le client Places.
// 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);.
Étape 3: Ajoutez le fournisseur de jetons
Après avoir initialisé l'API Places, appelez setPlacesAppCheckTokenProvider()
pour définir PlacesAppCheckTokenProvider
.
Places.initializeWithNewPlacesApiEnabled(context, API_KEY); Places.setPlacesAppCheckTokenProvider(new TokenProvider()); PlacesClient client = Places.createClient(context);.
Voici un exemple d'implémentation de l'interface de récupération de jetons:
/** 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; } }
Étape 4: Activez le débogage (facultatif)
Si vous souhaitez développer et tester votre application localement ou l'exécuter dans un environnement d'intégration continue (CI), vous pouvez créer un build de débogage de votre application qui utilise un secret de débogage pour obtenir des jetons App Check valides. Vous pouvez ainsi éviter d'utiliser de véritables fournisseurs d'attestation dans votre build de débogage.
Pour exécuter votre application dans un émulateur ou sur un appareil de test:
- Ajoutez la bibliothèque App Check à votre fichier
build.gradle
. - Configurez App Check pour qu'il utilise la fabrique du fournisseur de débogage dans votre version de débogage.
- Lancez l'application, qui créera un jeton de débogage local. Ajoutez ce jeton à la console Firebase.
- Pour en savoir plus et obtenir des instructions, consultez la documentation sur App Check.
Pour exécuter votre application dans un environnement de CI:
- Créez un jeton de débogage dans la console Firebase, puis ajoutez-le au magasin de clés sécurisé de votre système de CI.
- Ajoutez la bibliothèque App Check à votre fichier
build.gradle
. - Configurez la variante de compilation de votre CI pour qu'elle utilise le jeton de débogage.
- Encapsulez le code de vos classes de test qui nécessite un jeton App Check avec
DebugAppCheckTestHelper
. - Pour en savoir plus et obtenir des instructions, consultez la documentation sur App Check.
Étape 5: Surveillez les requêtes de votre application et décidez de la mise en œuvre
Avant de commencer à appliquer les mesures, vous devez vous assurer que vous ne perturberez pas les utilisateurs légitimes de votre application. Pour ce faire, accédez à l'écran des métriques App Check pour voir quel pourcentage du trafic de votre application est validé, obsolète ou non légitime. Une fois que vous constatez que la majorité de votre trafic est validé, vous pouvez activer l'application.
Pour en savoir plus et obtenir des instructions, consultez la documentation Firebase App Check.