Catch up on everthing we announced at this year's Firebase Summit. Learn more

जावास्क्रिप्ट का उपयोग करके एक से अधिक प्रमाणीकरण प्रदाताओं को एक खाते से लिंक करें

आप प्रमाणीकरण प्रदाता क्रेडेंशियल्स को मौजूदा उपयोगकर्ता खाते से लिंक करके एकाधिक प्रमाणीकरण प्रदाताओं का उपयोग करके उपयोगकर्ताओं को अपने ऐप में साइन इन करने की अनुमति दे सकते हैं। उपयोगकर्ता उसी Firebase उपयोगकर्ता आईडी से पहचाने जा सकते हैं, भले ही वे प्रमाणीकरण प्रदाता द्वारा साइन इन करने के लिए उपयोग किए गए हों। उदाहरण के लिए, पासवर्ड से साइन इन करने वाला उपयोगकर्ता Google खाते को लिंक कर सकता है और भविष्य में किसी भी विधि से साइन इन कर सकता है। या, कोई अनाम उपयोगकर्ता किसी Facebook खाते को लिंक कर सकता है और बाद में, आपके ऐप का उपयोग जारी रखने के लिए Facebook के साथ साइन इन कर सकता है।

शुरू करने से पहले

अपने ऐप में दो या अधिक प्रमाणीकरण प्रदाताओं (संभवतः अनाम प्रमाणीकरण सहित) के लिए समर्थन जोड़ें।

Google या Facebook जैसे प्रामाणिक प्रदाता से किसी मौजूदा उपयोगकर्ता खाते से क्रेडेंशियल लिंक करने के लिए:

  1. किसी प्रमाणीकरण प्रदाता या विधि का उपयोग करके उपयोगकर्ता में साइन इन करें।
  2. जाओ AuthProvider उद्देश्य यह है कि प्रदाता से मेल खाती है आप उपयोगकर्ता के खाते के लिए लिंक करना चाहते हैं। उदाहरण:

    वेब संस्करण 9

    import { GoogleAuthProvider, FacebookAuthProvider, TwitterAuthProvider, GithubAuthProvider } from "firebase/auth";
    
    const googleProvider = new GoogleAuthProvider();
    const facebookProvider = new FacebookAuthProvider();
    const twitterProvider = new TwitterAuthProvider();
    const githubProvider = new GithubAuthProvider();

    वेब संस्करण 8

    var googleProvider = new firebase.auth.GoogleAuthProvider();
    var facebookProvider = new firebase.auth.FacebookAuthProvider();
    var twitterProvider = new firebase.auth.TwitterAuthProvider();
    var githubProvider = new firebase.auth.GithubAuthProvider();
  3. उपयोगकर्ता को उस प्रदाता के साथ साइन इन करने के लिए कहें जिसे आप लिंक करना चाहते हैं। आप अपने उपयोगकर्ताओं को या तो एक पॉप-अप विंडो खोलकर या प्रदाता के साइन-इन पृष्ठ पर रीडायरेक्ट करके साइन इन करने के लिए प्रेरित कर सकते हैं। मोबाइल उपकरणों पर रीडायरेक्ट विधि को प्राथमिकता दी जाती है।
    • एक पॉप-अप विंडो साथ साइन-इन करने के लिए, कॉल linkWithPopup :

      वेब संस्करण 9

      import { getAuth, linkWithPopup, GoogleAuthProvider } from "firebase/auth";
      const provider = new GoogleAuthProvider();
      
      const auth = getAuth();
      linkWithPopup(auth.currentUser, provider).then((result) => {
        // Accounts successfully linked.
        const credential = GoogleAuthProvider.credentialFromResult(result);
        const user = result.user;
        // ...
      }).catch((error) => {
        // Handle Errors here.
        // ...
      });

      वेब संस्करण 8

      auth.currentUser.linkWithPopup(provider).then((result) => {
        // Accounts successfully linked.
        var credential = result.credential;
        var user = result.user;
        // ...
      }).catch((error) => {
        // Handle Errors here.
        // ...
      });
    • प्रदाता के लिए पुनः निर्देशित द्वारा प्रवेश करने के लिए साइन-इन पृष्ठ, कॉल linkWithRedirect :

      वेब संस्करण 9

      import { getAuth, linkWithRedirect, GoogleAuthProvider } from "firebase/auth";
      const provider = new GoogleAuthProvider();
      
      const auth = getAuth();
      linkWithRedirect(auth.currentUser, provider)
        .then(/* ... */)
        .catch(/* ... */);

      वेब संस्करण 8

      auth.currentUser.linkWithRedirect(provider)
        .then(/* ... */)
        .catch(/* ... */);
      उपयोगकर्ता साइन इन करने के बाद, उन्हें आपके पृष्ठ पर वापस भेज दिया जाता है। उसके बाद, आप फोन करके साइन-इन परिणाम प्राप्त कर सकते हैं getRedirectResult जब अपने पृष्ठ लोड:

      वेब संस्करण 9

      import { getRedirectResult } from "firebase/auth";
      getRedirectResult(auth).then((result) => {
        const credential = GoogleAuthProvider.credentialFromResult(result);
        if (credential) {
          // Accounts successfully linked.
          const user = result.user;
          // ...
        }
      }).catch((error) => {
        // Handle Errors here.
        // ...
      });

      वेब संस्करण 8

      auth.getRedirectResult().then((result) => {
        if (result.credential) {
          // Accounts successfully linked.
          var credential = result.credential;
          var user = result.user;
          // ...
        }
      }).catch((error) => {
        // Handle Errors here.
        // ...
      });
    यदि उपयोगकर्ता सफलतापूर्वक साइन इन है, तो प्रदाता के साथ उपयोगकर्ता का खाता आपके फ़ायरबेस प्रोजेक्ट में उपयोगकर्ता के खाते से लिंक है।

    यदि क्रेडेंशियल पहले से ही किसी अन्य उपयोगकर्ता खाते से लिंक हैं, तो खाता लिंकिंग विफल हो जाएगी। इस स्थिति में, आपको अपने ऐप के लिए उपयुक्त खातों और संबद्ध डेटा को मर्ज करने का प्रबंधन करना चाहिए:

    वेब संस्करण 9

    import { getAuth, signInWithCredential, linkWithCredential, OAuthProvider } from "firebase/auth";
    
    // The implementation of how you store your user data depends on your application
    const repo = new MyUserDataRepo();
    
    // Get reference to the currently signed-in user
    const auth = getAuth();
    const prevUser = auth.currentUser;
    
    // Get the data which you will want to merge. This should be done now
    // while the app is still signed in as this user.
    const prevUserData = repo.get(prevUser);
    
    // Delete the user's data now, we will restore it if the merge fails
    repo.delete(prevUser);
    
    // Sign in user with the account you want to link to
    signInWithCredential(auth, newCredential).then((result) => {
      console.log("Sign In Success", result);
      const currentUser = result.user;
      const currentUserData = repo.get(currentUser);
    
      // Merge prevUser and currentUser data stored in Firebase.
      // Note: How you handle this is specific to your application
      const mergedData = repo.merge(prevUserData, currentUserData);
    
      const credential = OAuthProvider.credentialFromResult(result);
      return linkWithCredential(prevUser, credential)
        .then((linkResult) => {
          // Sign in with the newly linked credential
          const linkCredential = OAuthProvider.credentialFromResult(linkResult);
          return signInWithCredential(auth, linkCredential);
        })
        .then((signInResult) => {
          // Save the merged data to the new user
          repo.set(signInResult.user, mergedData);
        });
    }).catch((error) => {
      // If there are errors we want to undo the data merge/deletion
      console.log("Sign In Error", error);
      repo.set(prevUser, prevUserData);
    });

    वेब संस्करण 8

    // The implementation of how you store your user data depends on your application
    var repo = new MyUserDataRepo();
    
    // Get reference to the currently signed-in user
    var prevUser = auth.currentUser;
    
    // Get the data which you will want to merge. This should be done now
    // while the app is still signed in as this user.
    var prevUserData = repo.get(prevUser);
    
    // Delete the user's data now, we will restore it if the merge fails
    repo.delete(prevUser);
    
    // Sign in user with the account you want to link to
    auth.signInWithCredential(newCredential).then((result) => {
      console.log("Sign In Success", result);
      var currentUser = result.user;
      var currentUserData = repo.get(currentUser);
    
      // Merge prevUser and currentUser data stored in Firebase.
      // Note: How you handle this is specific to your application
      var mergedData = repo.merge(prevUserData, currentUserData);
    
      return prevUser.linkWithCredential(result.credential)
        .then((linkResult) => {
          // Sign in with the newly linked credential
          return auth.signInWithCredential(linkResult.credential);
        })
        .then((signInResult) => {
          // Save the merged data to the new user
          repo.set(signInResult.user, mergedData);
        });
    }).catch((error) => {
      // If there are errors we want to undo the data merge/deletion
      console.log("Sign In Error", error);
      repo.set(prevUser, prevUserData);
    });

किसी मौजूदा उपयोगकर्ता खाते में ईमेल पता और पासवर्ड क्रेडेंशियल जोड़ने के लिए:

  1. किसी प्रमाणीकरण प्रदाता या विधि का उपयोग करके उपयोगकर्ता में साइन इन करें।
  2. उपयोगकर्ता को ईमेल पते और नए पासवर्ड के लिए संकेत दें।
  3. एक बनाएं AuthCredential ईमेल पता और पासवर्ड के साथ वस्तु:

    वेब संस्करण 9

    import { EmailAuthProvider } from "firebase/auth";
    
    const credential = EmailAuthProvider.credential(email, password);

    वेब संस्करण 8

    var credential = firebase.auth.EmailAuthProvider.credential(email, password);
  4. दर्रा AuthCredential पर आपत्ति साइन-इन उपयोगकर्ता के linkWithCredential विधि:

    वेब संस्करण 9

    import { getAuth, linkWithCredential } from "firebase/auth";
    
    const auth = getAuth();
    linkWithCredential(auth.currentUser, credential)
      .then((usercred) => {
        const user = usercred.user;
        console.log("Account linking success", user);
      }).catch((error) => {
        console.log("Account linking error", error);
      });

    वेब संस्करण 8

    auth.currentUser.linkWithCredential(credential)
      .then((usercred) => {
        var user = usercred.user;
        console.log("Account linking success", user);
      }).catch((error) => {
        console.log("Account linking error", error);
      });

    करने के लिए कॉल linkWithCredential यदि साख पहले से ही किसी अन्य उपयोगकर्ता खाते के साथ लिंक असफल हो जायेगी। इस स्थिति में, आपको अपने ऐप के लिए उपयुक्त खातों और संबंधित डेटा को मर्ज करने का प्रबंधन करना चाहिए (ऊपर उदाहरण देखें)।

आप किसी प्रमाणीकरण प्रदाता को किसी खाते से अनलिंक कर सकते हैं, ताकि उपयोगकर्ता अब उस प्रदाता के साथ साइन इन न कर सके।

एक उपयोगकर्ता खाते से एक प्रमाणन प्रदाता लिंक हटाने के लिए, करने के लिए प्रदाता आईडी पारित unlink विधि। आप से एक उपयोगकर्ता से जुड़ा हुआ प्रमाणन प्रदाताओं के प्रदाता आईडी प्राप्त कर सकते हैं providerData संपत्ति।

वेब संस्करण 9

import { getAuth, unlink } from "firebase/auth";

const auth = getAuth();
unlink(auth.currentUser, providerId).then(() => {
  // Auth provider unlinked from account
  // ...
}).catch((error) => {
  // An error happened
  // ...
});

वेब संस्करण 8

user.unlink(providerId).then(() => {
  // Auth provider unlinked from account
  // ...
}).catch((error) => {
  // An error happened
  // ...
});