Vous pouvez autoriser vos utilisateurs à s'authentifier auprès de Firebase à l'aide de leur compte Google. Vous pouvez soit utiliser le SDK Firebase pour exécuter le flux de connexion Google, soit exécuter la procédure de connexion manuellement à l'aide de la bibliothèque Se connecter avec Google et en transmettant 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 dans la section Authentification.
- Dans l'onglet Mode de connexion, activez le mode de connexion Google. et 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 leur compte Google est de gérer la procédure de connexion 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 la procédure de connexion avec le SDK Firebase JavaScript, procédez comme suit : étapes:
- 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 des habilitations OAuth 2.0 supplémentaires
que vous voulez demander
au fournisseur d'authentification. Pour ajouter un niveau d'accès, appelez
addScope
Exemple :provider.addScope('https://www.googleapis.com/auth/contacts.readonly');
provider.addScope('https://www.googleapis.com/auth/contacts.readonly');
- Facultatif: Localiser le flux OAuth du fournisseur selon les préférences de l'utilisateur
sans transmettre explicitement les paramètres OAuth personnalisés pertinents, modifiez la 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écifier d'autres paramètres de fournisseur OAuth personnalisés
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 de fournisseur Google. Vous pouvez
inviter vos utilisateurs à se connecter avec leur compte Google en ouvrant un
ou en vous redirigeant vers la page de connexion. La méthode de redirection est
de préférence sur
les appareils mobiles.
- Pour vous connecter via 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 Auth.
- Pour vous connecter en redirigeant l'utilisateur 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 via 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 seul 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 déjà
existe pour le fournisseur d'un autre utilisateur Firebase (comme Facebook), l'erreur
auth/account-exists-with-different-credential
est généré avec un
Objet AuthCredential
(jeton d'ID Google). Pour finaliser la connexion
le fournisseur souhaité, l'utilisateur doit d'abord se connecter au fournisseur existant (Facebook), puis créer un lien vers le
l'ancienne 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 la même manière en mode de redirection, à la différence que le bloc "Pending" les identifiants doivent être mis en cache entre les redirections de page (par exemple, en utilisant le 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 flux de connexion avec la bibliothèque Se connecter avec Google:
- Intégrez la fonctionnalité Se connecter avec Google dans votre application en suivant les guide d'intégration. Veillez à configurer Google Sign-In 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 Developers Console.
- 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é: S'authentifier avec Firebase dans Node.js
Pour vous authentifier avec Firebase dans une application Node.js :
- Connecter l'utilisateur avec son compte Google et obtenir l'ID Google de l'utilisateur
à partir d'un jeton d'accès. Pour ce faire, vous disposez de différentes méthodes. Par exemple :
- Si votre application dispose d'une interface de navigateur, utilisez Google Sign-In comme indiqué
dans la section Gérer
procédure de connexion manuelle. Obtenir le jeton d'ID Google à partir de l'authentification
réponse:
Envoyez ensuite ce jeton à votre application Node.js.var id_token = googleUser.getAuthResponse().id_token
- Si votre application s'exécute sur un appareil dont les capacités d'entrée sont limitées, comme un vous pouvez utiliser Google procédure de connexion pour les téléviseurs et les appareils.
- Si votre application dispose d'une interface de navigateur, utilisez Google Sign-In comme indiqué
dans la section Gérer
procédure de connexion manuelle. Obtenir le jeton d'ID Google à partir de l'authentification
réponse:
- Après avoir obtenu le jeton d'ID Google de l'utilisateur, utilisez-le pour créer un identifiant
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 développez une application d'extension Chrome, consultez la Guide des documents hors écran
Personnaliser le domaine de redirection pour Google Sign-In
Lors de la création du projet, Firebase provisionne un sous-domaine unique pour votre projet:
https://my-app-12345.firebaseapp.com
Il servira également de mécanisme de redirection pour la connexion OAuth. Ce domaine devrait ê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 Configurez 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 du
Console Firebase:
auth.custom.domain.com
. - Sur la Google Play Console ou sur la page de configuration OAuth, ajoutez l'URL de la page de redirection à la liste blanche.
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é à l'aide du paramètre
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és aux identifiants, c'est-à-dire au nom d'utilisateur et au mot de passe, ou des informations sur le fournisseur d'authentification, c'est-à-dire l'utilisateur avec lequel il s'est connecté. Cette nouvelle est stocké dans votre projet Firebase et peut servir à identifier un utilisateur dans toutes les applications de votre projet, quelle que soit la façon dont l'utilisateur se connecte.
-
Pour connaître l'état d'authentification de vos utilisateurs dans vos applications, définissez un observateur sur l'objet
Auth
. Vous pouvez ensuite obtenir les informations de profil de base de l'objetUser
. Voir Gérer les utilisateurs Dans votre Firebase Realtime Database et votre Cloud Storage Règles de sécurité, vous pouvez obtenez 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 appli à l'aide de plusieurs authentifications fournisseurs en associant leurs identifiants 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. });