Vous pouvez autoriser vos utilisateurs à s'authentifier avec Firebase à l'aide de leurs comptes Google. Vous pouvez utiliser le SDK Firebase pour effectuer le flux de connexion Google ou effectuer le flux de connexion manuellement à l'aide de la bibliothèque Se connecter avec Google et transmettre le jeton d'ID obtenu à Firebase.
Avant de commencer
- Ajoutez Firebase à votre projet JavaScript.
- Activez Google comme méthode de connexion dans la console Firebase :
- Dans la console Firebase, ouvrez la section Auth.
- Dans l'onglet Mode de connexion, activez la méthode de connexion Google, puis cliquez sur Enregistrer.
Gérer le flux de connexion avec le SDK Firebase
Si vous créez une application Web, le moyen le plus simple d'authentifier vos utilisateurs avec Firebase à l'aide de leurs comptes Google consiste à gérer le flux de connexion avec le SDK JavaScript Firebase. (Si vous souhaitez authentifier un utilisateur dans Node.js ou un autre environnement hors navigateur, vous devez gérer le flux de connexion manuellement.)
Pour gérer le flux de connexion avec le SDK JavaScript Firebase, procédez comme suit:
- Créez une instance de l'objet de fournisseur Google :
import { GoogleAuthProvider } from "firebase/auth"; const provider = new GoogleAuthProvider();
var provider = new firebase.auth.GoogleAuthProvider();
- Facultatif: spécifiez les champs d'application OAuth 2.0 supplémentaires que vous souhaitez demander au fournisseur d'authentification. Pour ajouter un champ d'application, appelez
addScope
. Exemple :provider.addScope('https://www.googleapis.com/auth/contacts.readonly');
provider.addScope('https://www.googleapis.com/auth/contacts.readonly');
- Facultatif: Pour localiser le flux OAuth du fournisseur dans la langue préférée de l'utilisateur sans transmettre explicitement les paramètres OAuth personnalisés pertinents, mettez à jour le code de langue sur l'instance Auth avant de démarrer le flux OAuth. Exemple :
import { getAuth } from "firebase/auth"; const auth = getAuth(); auth.languageCode = 'it'; // To apply the default browser preference instead of explicitly setting it. // auth.useDeviceLanguage();
firebase.auth().languageCode = 'it'; // To apply the default browser preference instead of explicitly setting it. // firebase.auth().useDeviceLanguage();
- Facultatif: spécifiez des paramètres de fournisseur OAuth personnalisés supplémentaires que vous souhaitez envoyer avec la requête OAuth. Pour ajouter un paramètre personnalisé, appelez
setCustomParameters
sur le fournisseur initialisé avec un objet contenant la clé telle que spécifiée par la documentation du fournisseur OAuth et la valeur correspondante. Exemple :provider.setCustomParameters({ 'login_hint': 'user@example.com' });
provider.setCustomParameters({ 'login_hint': 'user@example.com' });
- Authentifiez-vous avec Firebase à l'aide de l'objet du fournisseur Google. Vous pouvez inviter vos utilisateurs à se connecter avec leur compte Google en ouvrant une fenêtre pop-up ou en les redirigeant vers la page de connexion. La méthode de redirection est préférable sur les appareils mobiles.
- Pour vous connecter à l'aide d'une fenêtre pop-up, appelez
signInWithPopup
:import { getAuth, signInWithPopup, GoogleAuthProvider } from "firebase/auth"; const auth = getAuth(); signInWithPopup(auth, provider) .then((result) => { // This gives you a Google Access Token. You can use it to access the Google API. const credential = GoogleAuthProvider.credentialFromResult(result); const token = credential.accessToken; // The signed-in user info. const user = result.user; // IdP data available using getAdditionalUserInfo(result) // ... }).catch((error) => { // Handle Errors here. const errorCode = error.code; const errorMessage = error.message; // The email of the user's account used. const email = error.customData.email; // The AuthCredential type that was used. const credential = GoogleAuthProvider.credentialFromError(error); // ... });
firebase.auth() .signInWithPopup(provider) .then((result) => { /** @type {firebase.auth.OAuthCredential} */ var credential = result.credential; // This gives you a Google Access Token. You can use it to access the Google API. var token = credential.accessToken; // The signed-in user info. var user = result.user; // IdP data available in result.additionalUserInfo.profile. // ... }).catch((error) => { // Handle Errors here. var errorCode = error.code; var errorMessage = error.message; // The email of the user's account used. var email = error.email; // The firebase.auth.AuthCredential type that was used. var credential = error.credential; // ... });
C'est également là que vous pouvez détecter et gérer les erreurs. Pour obtenir la liste des codes d'erreur, consultez la documentation de référence sur l'authentification.
- Pour vous connecter en redirigeant vers la page de connexion, appelez
signInWithRedirect
: Suivez les bonnes pratiques lorsque vous utilisez "signInWithRedirect".import { getAuth, signInWithRedirect } from "firebase/auth"; const auth = getAuth(); signInWithRedirect(auth, provider);
firebase.auth().signInWithRedirect(provider);
getRedirectResult
lorsque votre page se charge:import { getAuth, getRedirectResult, GoogleAuthProvider } from "firebase/auth"; const auth = getAuth(); getRedirectResult(auth) .then((result) => { // This gives you a Google Access Token. You can use it to access Google APIs. const credential = GoogleAuthProvider.credentialFromResult(result); const token = credential.accessToken; // The signed-in user info. const user = result.user; // IdP data available using getAdditionalUserInfo(result) // ... }).catch((error) => { // Handle Errors here. const errorCode = error.code; const errorMessage = error.message; // The email of the user's account used. const email = error.customData.email; // The AuthCredential type that was used. const credential = GoogleAuthProvider.credentialFromError(error); // ... });
firebase.auth() .getRedirectResult() .then((result) => { if (result.credential) { /** @type {firebase.auth.OAuthCredential} */ var credential = result.credential; // This gives you a Google Access Token. You can use it to access the Google API. var token = credential.accessToken; // ... } // The signed-in user info. var user = result.user; // IdP data available in result.additionalUserInfo.profile. // ... }).catch((error) => { // Handle Errors here. var errorCode = error.code; var errorMessage = error.message; // The email of the user's account used. var email = error.email; // The firebase.auth.AuthCredential type that was used. var credential = error.credential; // ... });
- Pour vous connecter à l'aide d'une fenêtre pop-up, appelez
Gérer les erreurs de compte existant avec un identifiant différent
Si vous avez activé le paramètre Un compte par adresse e-mail dans la console Firebase, lorsqu'un utilisateur tente de se connecter à un fournisseur (tel que Google) avec une adresse e-mail existant déjà pour le fournisseur d'un autre utilisateur Firebase (tel que Facebook), l'erreur auth/account-exists-with-different-credential
est générée avec un objet AuthCredential
(jeton d'ID Google). Pour terminer la connexion au fournisseur souhaité, l'utilisateur doit d'abord se connecter au fournisseur existant (Facebook), puis l'associer à l'ancien AuthCredential
(jeton d'ID Google).
Mode pop-up
Si vous utilisez signInWithPopup
, vous pouvez gérer les erreurs auth/account-exists-with-different-credential
avec un code semblable à l'exemple suivant:
import { getAuth, linkWithCredential, signInWithPopup, GoogleAuthProvider, } from "firebase/auth"; try { // Step 1: User tries to sign in using Google. let result = await signInWithPopup(getAuth(), new GoogleAuthProvider()); } catch (error) { // Step 2: User's email already exists. if (error.code === "auth/account-exists-with-different-credential") { // The pending Google credential. let pendingCred = error.credential; // Step 3: Save the pending credential in temporary storage, // Step 4: Let the user know that they already have an account // but with a different provider, and let them choose another // sign-in method. } } // ... try { // Step 5: Sign the user in using their chosen method. let result = await signInWithPopup(getAuth(), userSelectedProvider); // Step 6: Link to the Google credential. // TODO: implement `retrievePendingCred` for your app. let pendingCred = retrievePendingCred(); if (pendingCred !== null) { // As you have access to the pending credential, you can directly call the // link method. let user = await linkWithCredential(result.user, pendingCred); } // Step 7: Continue to app. } catch (error) { // ... }
Mode de redirection
Cette erreur est gérée de manière similaire en mode redirection, à la différence que les identifiants en attente doivent être mis en cache entre les redirections de pages (par exemple, en utilisant l'espace de stockage de session).
Avancé: gérer manuellement le flux de connexion
Vous pouvez également vous authentifier avec Firebase à l'aide d'un compte Google en gérant le flux de connexion avec la bibliothèque Se connecter avec Google:
- Intégrez Se connecter avec Google à votre application en suivant le guide d'intégration. Veillez à configurer la connexion Google avec l'ID client Google généré pour votre projet Firebase. Vous trouverez l'ID client Google de votre projet sur la page Identifiants de la console pour les développeurs de votre projet.
- Dans le rappel du résultat de la connexion, échangez le jeton d'identification de la réponse d'authentification Google contre des identifiants Firebase, puis utilisez-les pour vous authentifier avec Firebase:
function handleCredentialResponse(response) { // Build Firebase credential with the Google ID token. const idToken = response.credential; const credential = GoogleAuthProvider.credential(idToken); // Sign in with credential from the Google user. signInWithCredential(auth, credential).catch((error) => { // Handle Errors here. const errorCode = error.code; const errorMessage = error.message; // The email of the user's account used. const email = error.email; // The credential that was used. const credential = GoogleAuthProvider.credentialFromError(error); // ... }); }
Avancé: Authentifier avec Firebase dans Node.js
Pour vous authentifier avec Firebase dans une application Node.js:
- Connectez l'utilisateur avec son compte Google et obtenez son jeton d'ID Google. Pour ce faire, vous pouvez procéder de différentes manières. Par exemple :
- Si votre application dispose d'un front-end de navigateur, utilisez Google Sign-In comme décrit dans la section Gérer manuellement le flux de connexion. Obtenez le jeton d'ID Google à partir de la réponse d'authentification:
Ensuite, envoyez ce jeton à votre application Node.js.var id_token = googleUser.getAuthResponse().id_token
- Si votre application s'exécute sur un appareil aux fonctionnalités d'entrée limitées, comme un téléviseur, vous pouvez utiliser le flux Connexion Google pour les téléviseurs et les appareils.
- Si votre application dispose d'un front-end de navigateur, utilisez Google Sign-In comme décrit dans la section Gérer manuellement le flux de connexion. Obtenez le jeton d'ID Google à partir de la réponse d'authentification:
- Une fois que vous avez obtenu le jeton d'identifiant Google de l'utilisateur, utilisez-le pour créer un objet Credential, puis connectez l'utilisateur avec les identifiants:
import { getAuth, signInWithCredential, GoogleAuthProvider } from "firebase/auth"; // Build Firebase credential with the Google ID token. const credential = GoogleAuthProvider.credential(id_token); // Sign in with credential from the Google user. const auth = getAuth(); signInWithCredential(auth, credential).catch((error) => { // Handle Errors here. const errorCode = error.code; const errorMessage = error.message; // The email of the user's account used. const email = error.customData.email; // The AuthCredential type that was used. const credential = GoogleAuthProvider.credentialFromError(error); // ... });
// Build Firebase credential with the Google ID token. var credential = firebase.auth.GoogleAuthProvider.credential(id_token); // Sign in with credential from the Google user. firebase.auth().signInWithCredential(credential).catch((error) => { // Handle Errors here. var errorCode = error.code; var errorMessage = error.message; // The email of the user's account used. var email = error.email; // The firebase.auth.AuthCredential type that was used. var credential = error.credential; // ... });
S'authentifier avec Firebase dans une extension Chrome
Si vous créez une application d'extension Chrome, consultez le guide sur les documents hors écran.
Personnaliser le domaine de redirection pour la connexion Google
Lors de la création du projet, Firebase provisionne un sous-domaine unique pour votre projet : https://my-app-12345.firebaseapp.com
.
Il sera également utilisé comme mécanisme de redirection pour la connexion OAuth. Ce domaine doit être autorisé pour tous les fournisseurs OAuth compatibles. Toutefois, cela signifie que les utilisateurs peuvent voir ce domaine lorsqu'ils se connectent à Google avant d'être redirigés vers l'application : Continuer à: https://my-app-12345.firebaseapp.com.
Pour éviter d'afficher votre sous-domaine, vous pouvez configurer un domaine personnalisé avec Firebase Hosting:
- Suivez les étapes 1 à 3 de la section Configurer votre domaine pour Hosting. Lorsque vous validez la propriété de votre domaine, Hosting provisionne un certificat SSL pour votre domaine personnalisé.
- Ajoutez votre domaine personnalisé à la liste des domaines autorisés dans la console Firebase:
auth.custom.domain.com
. - Dans la console de développement Google ou sur la page de configuration OAuth, ajoutez à la liste blanche l'URL de la page de redirection, qui sera accessible sur votre domaine personnalisé :
https://auth.custom.domain.com/__/auth/handler
. - Lorsque vous initialisez la bibliothèque JavaScript, spécifiez votre domaine personnalisé avec le champ
authDomain
:var config = { apiKey: '...', // Changed from '
PROJECT_ID .firebaseapp.com'. authDomain: 'auth.custom.domain.com', databaseURL: 'https://PROJECT_ID .firebaseio.com', projectId: 'PROJECT_ID ', storageBucket: ' ', messagingSenderId: 'PROJECT_ID .firebasestorage.appSENDER_ID ' }; firebase.initializeApp(config);
Étapes suivantes
Lorsqu'un utilisateur se connecte pour la première fois, un compte utilisateur est créé et associé aux identifiants (nom d'utilisateur et mot de passe, numéro de téléphone ou informations du fournisseur d'authentification) avec lesquels l'utilisateur s'est connecté. Ce nouveau compte est stocké dans votre projet Firebase et peut être utilisé pour identifier un utilisateur dans toutes les applications de votre projet, quelle que soit la manière dont il se connecte.
-
Dans vos applications, la méthode recommandée pour connaître l'état d'authentification de votre utilisateur consiste à définir un observateur sur l'objet
Auth
. Vous pouvez ensuite obtenir les informations de profil de base de l'utilisateur à partir de l'objetUser
. Consultez la section Gérer les utilisateurs. Dans vos règles de sécurité Firebase Realtime Database et Cloud Storage, vous pouvez obtenir l'ID utilisateur unique de l'utilisateur connecté à partir de la variable
auth
et l'utiliser pour contrôler les données auxquelles un utilisateur peut accéder.
Vous pouvez autoriser les utilisateurs à se connecter à votre application à l'aide de plusieurs fournisseurs d'authentification en associant les identifiants du fournisseur d'authentification à un compte utilisateur existant.
Pour déconnecter un utilisateur, appelez
signOut
:
import { getAuth, signOut } from "firebase/auth"; const auth = getAuth(); signOut(auth).then(() => { // Sign-out successful. }).catch((error) => { // An error happened. });
firebase.auth().signOut().then(() => { // Sign-out successful. }).catch((error) => { // An error happened. });