S'authentifier à l'aide de Google avec JavaScript

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

  1. Ajoutez Firebase à votre projet JavaScript.
  2. Activez Google comme méthode de connexion dans la console Firebase :
    1. Dans la console Firebase, ouvrez dans la section Authentification.
    2. 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:

  1. Créez une instance de l'objet de fournisseur Google :
    WebWeb
    import { GoogleAuthProvider } from "firebase/auth";
    
    const provider = new GoogleAuthProvider();
    var provider = new firebase.auth.GoogleAuthProvider();
  2. 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 :
    WebWeb
    provider.addScope('https://www.googleapis.com/auth/contacts.readonly');
    provider.addScope('https://www.googleapis.com/auth/contacts.readonly');
    Voir le fournisseur d'authentification documentation.
  3. 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 :
    WebWeb
    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();
  4. 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 :
    WebWeb
    provider.setCustomParameters({
      'login_hint': 'user@example.com'
    });
    provider.setCustomParameters({
      'login_hint': 'user@example.com'
    });
    Les paramètres OAuth obligatoires réservés ne sont pas autorisés et seront ignorés. Consultez les documentation de référence sur le fournisseur d'authentification.
  5. 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:
      WebWeb
      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;
          // ...
        });
      Notez également que vous pouvez récupérer le jeton OAuth du fournisseur Google, qui peut être utilisé pour récupérer des données supplémentaires à l'aide des API Google.

      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".
      WebWeb
      import { getAuth, signInWithRedirect } from "firebase/auth";
      
      const auth = getAuth();
      signInWithRedirect(auth, provider);
      firebase.auth().signInWithRedirect(provider);
      Vous pouvez ensuite également récupérer le jeton OAuth du fournisseur Google en appelant getRedirectResult lorsque votre page se charge:
      WebWeb
      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;
          // ...
        });
      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.

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).

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).

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:

  1. 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.
  2. 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);
        // ...
      });
    }

Pour vous authentifier avec Firebase dans une application Node.js :

  1. 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 :
  2. 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:
    WebWeb
    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

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:

  1. 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é.
  2. Ajoutez votre domaine personnalisé à la liste des domaines autorisés du Console Firebase: auth.custom.domain.com.
  3. 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
  4. 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: 'PROJECT_ID.firebasestorage.app',
      messagingSenderId: 'SENDER_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'objet User. 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:

WebWeb
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.
});