Join us for Firebase Summit on November 10, 2021. Tune in to learn how Firebase can help you accelerate app development, release with confidence, and scale with ease. Register

फ़ोन नंबर का उपयोग करके iOS पर Firebase से प्रमाणित करें

आप उपयोगकर्ता के फ़ोन पर एक SMS संदेश भेजकर उपयोगकर्ता में साइन इन करने के लिए Firebase प्रमाणीकरण का उपयोग कर सकते हैं। उपयोगकर्ता एसएमएस संदेश में निहित वन-टाइम कोड का उपयोग करके साइन इन करता है।

फोन नंबर के साइन-इन को जोड़ने के लिए सबसे आसान तरीका करने के लिए आपके एप्लिकेशन का उपयोग करने के लिए है FirebaseUI है, जो एक ड्रॉप-में शामिल विजेट साइन-इन औजारों फोन नंबर के लिए साइन-इन कि प्रवाह साइन-इन, साथ ही पासवर्ड आधारित और फ़ेडेरेटेड साइन -में। यह दस्तावेज़ वर्णन करता है कि Firebase SDK का उपयोग करके फ़ोन नंबर साइन-इन प्रवाह को कैसे कार्यान्वित किया जाए।

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

  1. अपने iOS परियोजना के लिए Firebase जोड़े
  2. अपने में निम्नलिखित फली शामिल Podfile :
    pod 'Firebase/Auth'
    
  3. आपने अभी तक अपना Firebase परियोजना के लिए अपने app जुड़ा नहीं किया है, से ऐसा कर Firebase कंसोल

सुरक्षा चिंताएं

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

यदि आप अपने ऐप में फ़ोन नंबर आधारित साइन-इन का उपयोग करते हैं, तो आपको इसे अधिक सुरक्षित साइन-इन विधियों के साथ पेश करना चाहिए, और उपयोगकर्ताओं को फ़ोन नंबर साइन-इन का उपयोग करने के लिए सुरक्षा ट्रेडऑफ़ के बारे में सूचित करना चाहिए।

अपने Firebase प्रोजेक्ट के लिए फ़ोन नंबर साइन-इन सक्षम करें

SMS द्वारा उपयोगकर्ताओं में साइन इन करने के लिए, आपको पहले अपने Firebase प्रोजेक्ट के लिए फ़ोन नंबर साइन-इन विधि को सक्षम करना होगा:

  1. में Firebase कंसोल , प्रमाणीकरण अनुभाग खोलें।
  2. साइन-इन विधि पृष्ठ पर, फोन नंबर साइन-इन विधि सक्षम करें।

Firebase का फ़ोन नंबर साइन-इन अनुरोध कोटा इतना अधिक है कि अधिकांश ऐप्स प्रभावित नहीं होंगे। हालाँकि, यदि आपको फ़ोन प्रमाणीकरण के साथ बहुत अधिक मात्रा में उपयोगकर्ताओं में साइन इन करने की आवश्यकता है, तो आपको अपनी मूल्य निर्धारण योजना को अपग्रेड करने की आवश्यकता हो सकती है। देखें मूल्य निर्धारण पेज।

ऐप सत्यापन सक्षम करें

फ़ोन नंबर प्रमाणीकरण का उपयोग करने के लिए, Firebase को यह सत्यापित करने में सक्षम होना चाहिए कि आपके ऐप से फ़ोन नंबर साइन-इन अनुरोध आ रहे हैं। Firebase प्रमाणीकरण इसे पूरा करने के दो तरीके हैं:

  • मौन APN के अधिसूचना: जब आप एक डिवाइस पर पहली बार के लिए उनके फोन नंबर के साथ एक उपयोगकर्ता के लिए साइन करते Firebase प्रमाणीकरण एक मूक पुश अधिसूचना उपयोग करके उपकरण से टोकन भेजता है। अगर आपका ऐप्लिकेशन Firebase से सफलतापूर्वक सूचना प्राप्त करता है, तो फ़ोन नंबर साइन-इन आगे बढ़ सकता है।

    IOS 8.0 और नए के लिए, मूक सूचनाओं के लिए स्पष्ट उपयोगकर्ता सहमति की आवश्यकता नहीं होती है और इसलिए उपयोगकर्ता द्वारा ऐप में APNs सूचनाएं प्राप्त करने से इनकार करने से अप्रभावित रहता है। इस प्रकार, ऐप को फ़ायरबेस फ़ोन नंबर प्रमाणीकरण लागू करते समय पुश नोटिफिकेशन प्राप्त करने के लिए उपयोगकर्ता की अनुमति का अनुरोध करने की आवश्यकता नहीं है।

  • reCAPTCHA सत्यापन: घटना है कि भेजने या एक मूक पुश अधिसूचना प्राप्त करने जैसे जब उपयोगकर्ता अपने अनुप्रयोग के लिए विकलांग पृष्ठभूमि ताज़ा है के रूप में संभव नहीं है, में, या जब एक iOS सिम्युलेटर पर अपने ऐप का परीक्षण, Firebase प्रमाणीकरण reCAPTCHA सत्यापन फ़ोन पूरा करने के लिए उपयोग करता है साइन-इन प्रवाह। उपयोगकर्ता को कुछ भी हल किए बिना रीकैप्चा चुनौती को अक्सर पूरा किया जा सकता है।

जब मूक पुश सूचनाएं ठीक से कॉन्फ़िगर की जाती हैं, तो केवल बहुत कम प्रतिशत उपयोगकर्ता ही रीकैप्चा प्रवाह का अनुभव करेंगे। फिर भी, आपको यह सुनिश्चित करना चाहिए कि फ़ोन नंबर साइन-इन सही ढंग से कार्य करता है चाहे साइलेंट पुश नोटिफिकेशन उपलब्ध हों या नहीं।

मौन सूचनाएं प्राप्त करना प्रारंभ करें

फायरबेस प्रमाणीकरण के साथ उपयोग के लिए एपीएन अधिसूचनाओं को सक्षम करने के लिए:

  1. Xcode में, पुश सूचनाएं सक्षम अपनी परियोजना के लिए।
  2. Firebase पर अपनी APN प्रमाणीकरण कुंजी अपलोड करें. आप पहले से ही एक APN के प्रमाणीकरण कुंजी नहीं है, तो में एक बनाने के लिए सुनिश्चित करें कि Apple डेवलपर सदस्य केंद्र

    1. Firebase कंसोल में अपनी परियोजना के अंदर,, गियर आइकन परियोजना सेटिंग्स का चयन करें, और उसके बाद क्लाउड संदेश टैब का चयन करें।

    2. IOS अनुप्रयोग विन्यास के तहत APN के प्रमाणीकरण कुंजी में, अपलोड बटन क्लिक करें।

    3. स्थान जहाँ आप अपने कुंजी बचाया के लिए ब्राउज़ करें, उसका चयन करें, और खोलें क्लिक करें। कुंजी (में उपलब्ध के लिए कुंजी आईडी जोड़ें Apple डेवलपर सदस्य केंद्र ) और अपलोड क्लिक करें।

    यदि आपके पास पहले से APN प्रमाणपत्र है, तो आप इसके बजाय प्रमाणपत्र अपलोड कर सकते हैं।

रीकैप्चा सत्यापन सेट करें

फायरबेस एसडीके को रीकैप्चा सत्यापन का उपयोग करने के लिए सक्षम करने के लिए:

  1. अपने Xcode प्रोजेक्ट में कस्टम URL स्कीम जोड़ें:
    1. अपना प्रोजेक्ट कॉन्फ़िगरेशन खोलें: बाएँ ट्री व्यू में प्रोजेक्ट नाम पर डबल-क्लिक करें। , लक्ष्य अनुभाग से अपना ऐप चुनें तो जानकारी टैब का चयन करें, और यूआरएल प्रकार अनुभाग को विस्तृत।
    2. + बटन क्लिक करें, और अपने उलट ग्राहक आईडी के लिए एक यूआरएल स्कीम जोड़ें। इस मान को खोजने के लिए, खोलने GoogleService-Info.plist विन्यास फाइल, और के लिए देखो REVERSED_CLIENT_ID कुंजी। उस कुंजी के मान को कॉपी करके यूआरएल योजनाएं विन्यास पृष्ठ पर बॉक्स में पेस्ट करें। अन्य क्षेत्रों को खाली छोड़ दें।

      पूरा होने पर, आपकी कॉन्फ़िगरेशन निम्न के जैसा कुछ दिखना चाहिए (लेकिन आपके एप्लिकेशन-विशिष्ट मानों के साथ):

  2. वैकल्पिक: यदि आप जिस तरह से अपने अनुप्रयोग प्रस्तुत कस्टमाइज़ करना चाहते हैं SFSafariViewController या UIWebView जब उपयोगकर्ता के लिए reCAPTCHA प्रदर्शित करने, एक कस्टम वर्ग के अनुरूप बनाने के FIRAuthUIDelegate प्रोटोकॉल, और करने के लिए इसे पारित verifyPhoneNumber:UIDelegate:completion:

उपयोगकर्ता के फ़ोन पर सत्यापन कोड भेजें

आरंभ करने के लिए फोन नंबर है कि उन्हें संकेतों उनके फोन नंबर प्रदान करने के लिए साइन-इन, उपयोगकर्ता एक इंटरफेस पेश, और फिर फोन verifyPhoneNumber:UIDelegate:completion: अनुरोध है कि Firebase एसएमएस द्वारा उपयोगकर्ता के फ़ोन पर एक प्रमाणीकरण कोड भेजें:

  1. उपयोगकर्ता का फ़ोन नंबर प्राप्त करें।

    कानूनी आवश्यकताएं अलग-अलग होती हैं, लेकिन सर्वोत्तम अभ्यास के रूप में और अपने उपयोगकर्ताओं के लिए अपेक्षाएं निर्धारित करने के लिए, आपको उन्हें सूचित करना चाहिए कि यदि वे फ़ोन साइन-इन का उपयोग करते हैं, तो उन्हें सत्यापन के लिए एक एसएमएस संदेश प्राप्त हो सकता है और मानक दरें लागू हो सकती हैं।

  2. कॉल verifyPhoneNumber:UIDelegate:completion: , यह करने के लिए उपयोगकर्ता का फ़ोन नंबर गुजर।

    तीव्र

    PhoneAuthProvider.provider()
      .verifyPhoneNumber(phoneNumber, uiDelegate: nil) { verificationID, error in
          if let error = error {
            self.showMessagePrompt(error.localizedDescription)
            return
          }
          // Sign in using the verificationID and the code sent to the user
          // ...
      }

    उद्देश्य सी

    [[FIRPhoneAuthProvider provider] verifyPhoneNumber:userInput
                                            UIDelegate:nil
                                            completion:^(NSString * _Nullable verificationID, NSError * _Nullable error) {
      if (error) {
        [self showMessagePrompt:error.localizedDescription];
        return;
      }
      // Sign in using the verificationID and the code sent to the user
      // ...
    }];

    जब आप फोन verifyPhoneNumber:UIDelegate:completion: , Firebase एक मूक पुश अधिसूचना अपने अनुप्रयोग के लिए भेजता है, या मुद्दों उपयोगकर्ता के लिए एक reCAPTCHA चुनौती। जब आपका ऐप नोटिफिकेशन प्राप्त करता है या उपयोगकर्ता रीकैप्चा चुनौती को पूरा करता है, तो फायरबेस निर्दिष्ट फोन नंबर पर एक प्रमाणीकरण कोड वाला एक एसएमएस संदेश भेजता है और आपके पूरा होने के कार्य के लिए एक सत्यापन आईडी पास करता है। उपयोगकर्ता में साइन इन करने के लिए आपको सत्यापन कोड और सत्यापन आईडी दोनों की आवश्यकता होगी।

    एसएमएस Firebase द्वारा भेजे गए संदेश के माध्यम से भी प्रमाणन भाषा निर्दिष्ट करने के द्वारा किया जा सकता है स्थानीय languageCode अपने प्रमाणीकरण उदाहरण पर संपत्ति।

    तीव्र

     // Change language code to french.
     Auth.auth().languageCode = "fr";
    

    उद्देश्य सी

     // Change language code to french.
     [FIRAuth auth].languageCode = @"fr";
    
  3. सत्यापन आईडी सहेजें और जब आपका ऐप लोड हो जाए तो उसे पुनर्स्थापित करें। ऐसा करने से, आप यह सुनिश्चित कर सकते हैं कि उपयोगकर्ता द्वारा साइन-इन प्रवाह पूरा करने से पहले (उदाहरण के लिए, एसएमएस ऐप पर स्विच करते समय) आपका ऐप समाप्त होने पर भी आपके पास एक वैध सत्यापन आईडी है।

    आप किसी भी तरह से सत्यापन आईडी जारी रख सकते हैं। एक आसान तरीका के साथ सत्यापन आईडी को बचाने के लिए है NSUserDefaults वस्तु:

    तीव्र

    UserDefaults.standard.set(verificationID, forKey: "authVerificationID")
    

    उद्देश्य सी

    NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
    [defaults setObject:verificationID forKey:@"authVerificationID"];
    

    फिर, आप सहेजे गए मान को पुनर्स्थापित कर सकते हैं:

    तीव्र

    let verificationID = UserDefaults.standard.string(forKey: "authVerificationID")
    

    उद्देश्य सी

    NSString *verificationID = [defaults stringForKey:@"authVerificationID"];
    

करने के लिए कॉल तो verifyPhoneNumber:UIDelegate:completion: सफल होता है, आप जब वे एसएमएस संदेश में इसे प्राप्त सत्यापन कोड टाइप करने के लिए उपयोगकर्ता का संकेत दे सकता।

सत्यापन कोड के साथ उपयोगकर्ता में साइन इन करें

उपयोगकर्ता एसएमएस संदेश से सत्यापन कोड के साथ आपके एप्लिकेशन के बाद, एक बनाने के द्वारा में उपयोगकर्ता हस्ताक्षर FIRPhoneAuthCredential सत्यापन कोड और सत्यापन आईडी से वस्तु और करने के लिए उस वस्तु गुजर signInWithCredential:completion:

  1. उपयोगकर्ता से सत्यापन कोड प्राप्त करें।
  2. एक बनाएं FIRPhoneAuthCredential सत्यापन कोड और सत्यापन आईडी से वस्तु।

    तीव्र

    let credential = PhoneAuthProvider.provider().credential(
      withVerificationID: verificationID,
      verificationCode: verificationCode
    )

    उद्देश्य सी

    FIRAuthCredential *credential = [[FIRPhoneAuthProvider provider]
        credentialWithVerificationID:verificationID
                    verificationCode:userInput];
  3. साथ उपयोगकर्ता में साइन इन करें FIRPhoneAuthCredential वस्तु:

    तीव्र

    Auth.auth().signIn(with: credential) { authResult, error in
        if let error = error {
          let authError = error as NSError
          if isMFAEnabled, authError.code == AuthErrorCode.secondFactorRequired.rawValue {
            // The user is a multi-factor user. Second factor challenge is required.
            let resolver = authError
              .userInfo[AuthErrorUserInfoMultiFactorResolverKey] as! MultiFactorResolver
            var displayNameString = ""
            for tmpFactorInfo in resolver.hints {
              displayNameString += tmpFactorInfo.displayName ?? ""
              displayNameString += " "
            }
            self.showTextInputPrompt(
              withMessage: "Select factor to sign in\n\(displayNameString)",
              completionBlock: { userPressedOK, displayName in
                var selectedHint: PhoneMultiFactorInfo?
                for tmpFactorInfo in resolver.hints {
                  if displayName == tmpFactorInfo.displayName {
                    selectedHint = tmpFactorInfo as? PhoneMultiFactorInfo
                  }
                }
                PhoneAuthProvider.provider()
                  .verifyPhoneNumber(with: selectedHint!, uiDelegate: nil,
                                     multiFactorSession: resolver
                                       .session) { verificationID, error in
                    if error != nil {
                      print(
                        "Multi factor start sign in failed. Error: \(error.debugDescription)"
                      )
                    } else {
                      self.showTextInputPrompt(
                        withMessage: "Verification code for \(selectedHint?.displayName ?? "")",
                        completionBlock: { userPressedOK, verificationCode in
                          let credential: PhoneAuthCredential? = PhoneAuthProvider.provider()
                            .credential(withVerificationID: verificationID!,
                                        verificationCode: verificationCode!)
                          let assertion: MultiFactorAssertion? = PhoneMultiFactorGenerator
                            .assertion(with: credential!)
                          resolver.resolveSignIn(with: assertion!) { authResult, error in
                            if error != nil {
                              print(
                                "Multi factor finanlize sign in failed. Error: \(error.debugDescription)"
                              )
                            } else {
                              self.navigationController?.popViewController(animated: true)
                            }
                          }
                        }
                      )
                    }
                  }
              }
            )
          } else {
            self.showMessagePrompt(error.localizedDescription)
            return
          }
          // ...
          return
        }
        // User is signed in
        // ...
    }

    उद्देश्य सी

    [[FIRAuth auth] signInWithCredential:credential
                              completion:^(FIRAuthDataResult * _Nullable authResult,
                                           NSError * _Nullable error) {
        if (isMFAEnabled && error && error.code == FIRAuthErrorCodeSecondFactorRequired) {
          FIRMultiFactorResolver *resolver = error.userInfo[FIRAuthErrorUserInfoMultiFactorResolverKey];
          NSMutableString *displayNameString = [NSMutableString string];
          for (FIRMultiFactorInfo *tmpFactorInfo in resolver.hints) {
            [displayNameString appendString:tmpFactorInfo.displayName];
            [displayNameString appendString:@" "];
          }
          [self showTextInputPromptWithMessage:[NSString stringWithFormat:@"Select factor to sign in\n%@", displayNameString]
                               completionBlock:^(BOOL userPressedOK, NSString *_Nullable displayName) {
           FIRPhoneMultiFactorInfo* selectedHint;
           for (FIRMultiFactorInfo *tmpFactorInfo in resolver.hints) {
             if ([displayName isEqualToString:tmpFactorInfo.displayName]) {
               selectedHint = (FIRPhoneMultiFactorInfo *)tmpFactorInfo;
             }
           }
           [FIRPhoneAuthProvider.provider
            verifyPhoneNumberWithMultiFactorInfo:selectedHint
            UIDelegate:nil
            multiFactorSession:resolver.session
            completion:^(NSString * _Nullable verificationID, NSError * _Nullable error) {
              if (error) {
                [self showMessagePrompt:error.localizedDescription];
              } else {
                [self showTextInputPromptWithMessage:[NSString stringWithFormat:@"Verification code for %@", selectedHint.displayName]
                                     completionBlock:^(BOOL userPressedOK, NSString *_Nullable verificationCode) {
                 FIRPhoneAuthCredential *credential =
                     [[FIRPhoneAuthProvider provider] credentialWithVerificationID:verificationID
                                                                  verificationCode:verificationCode];
                 FIRMultiFactorAssertion *assertion = [FIRPhoneMultiFactorGenerator assertionWithCredential:credential];
                 [resolver resolveSignInWithAssertion:assertion completion:^(FIRAuthDataResult * _Nullable authResult, NSError * _Nullable error) {
                   if (error) {
                     [self showMessagePrompt:error.localizedDescription];
                   } else {
                     NSLog(@"Multi factor finanlize sign in succeeded.");
                   }
                 }];
               }];
              }
            }];
         }];
        }
      else if (error) {
        // ...
        return;
      }
      // User successfully signed in. Get user data from the FIRUser object
      if (authResult == nil) { return; }
      FIRUser *user = authResult.user;
      // ...
    }];

काल्पनिक फ़ोन नंबरों के साथ परीक्षण करें

आप Firebase कंसोल के माध्यम से विकास के लिए काल्पनिक फ़ोन नंबर सेट कर सकते हैं। काल्पनिक फ़ोन नंबरों के साथ परीक्षण करने से ये लाभ मिलते हैं:

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

काल्पनिक फ़ोन नंबरों को इन आवश्यकताओं को पूरा करना चाहिए:

  1. सुनिश्चित करें कि आप उन फ़ोन नंबरों का उपयोग करते हैं जो वास्तव में काल्पनिक हैं, और पहले से मौजूद नहीं हैं। फायरबेस प्रमाणीकरण आपको वास्तविक उपयोगकर्ताओं द्वारा उपयोग किए जाने वाले मौजूदा फ़ोन नंबरों को परीक्षण संख्या के रूप में सेट करने की अनुमति नहीं देता है। एक विकल्प उदाहरण के लिए, अमेरिका परीक्षण फोन नंबर के रूप में 555 के उपसर्ग में नंबरों का उपयोग करने के लिए है: +1 650-555-3434
  2. लंबाई और अन्य बाधाओं के लिए फ़ोन नंबरों को सही ढंग से स्वरूपित करना होगा। वे अभी भी वास्तविक उपयोगकर्ता के फ़ोन नंबर के समान सत्यापन से गुज़रेंगे।
  3. आप विकास के लिए अधिकतम 10 फ़ोन नंबर जोड़ सकते हैं।
  4. ऐसे परीक्षण फ़ोन नंबरों/कोडों का उपयोग करें जिनका अनुमान लगाना कठिन है और उन्हें बार-बार बदलें।

काल्पनिक फ़ोन नंबर और सत्यापन कोड बनाएं

  1. में Firebase कंसोल , प्रमाणीकरण अनुभाग खोलें।
  2. यदि आपने ऐसा नहीं किया विधि टैब में साइन इन करें, फोन प्रदाता को सक्षम।
  3. अकॉर्डियन मेनू के परीक्षण के लिए फ़ोन नंबरों में खोलें।
  4. , आप परीक्षण करना चाहते हैं फ़ोन नंबर उपलब्ध कराएं उदाहरण के लिए: +1 650-555-3434।
  5. कि विशिष्ट संख्या के लिए 6 अंकों वाला सत्यापन कोड प्रदान करें, उदाहरण के लिए: 654321।
  6. नंबर जोड़ें। यदि कोई आवश्यकता है, तो आप संबंधित पंक्ति पर होवर करके और ट्रैश आइकन पर क्लिक करके फ़ोन नंबर और उसका कोड हटा सकते हैं।

मैनुअल परीक्षण

आप सीधे अपने आवेदन में एक काल्पनिक फोन नंबर का उपयोग शुरू कर सकते हैं। यह आपको कोटा मुद्दों या थ्रॉटलिंग में भागे बिना विकास चरणों के दौरान मैन्युअल परीक्षण करने की अनुमति देता है। आप Google Play सेवाओं को स्थापित किए बिना सीधे iOS सिम्युलेटर या Android एमुलेटर से भी परीक्षण कर सकते हैं।

जब आप काल्पनिक फ़ोन नंबर प्रदान करते हैं और सत्यापन कोड भेजते हैं, तो कोई वास्तविक एसएमएस नहीं भेजा जाता है। इसके बजाय, आपको साइन इन पूरा करने के लिए पहले से कॉन्फ़िगर किया गया सत्यापन कोड प्रदान करना होगा।

साइन-इन पूरा होने पर, उस फ़ोन नंबर के साथ एक Firebase उपयोगकर्ता बनाया जाता है। उपयोगकर्ता के पास वास्तविक फ़ोन नंबर उपयोगकर्ता के समान व्यवहार और गुण होते हैं, और उसी तरह रीयलटाइम डेटाबेस/क्लाउड फायरस्टोर और अन्य सेवाओं तक पहुंच सकते हैं। इस प्रक्रिया के दौरान बनाए गए आईडी टोकन में वास्तविक फोन नंबर उपयोगकर्ता के समान हस्ताक्षर होते हैं।

एक अन्य विकल्प के लिए है के माध्यम से कस्टम का दावा है एक परीक्षण भूमिका सेट इन उपयोगकर्ताओं पर नकली उपयोगकर्ताओं के रूप में उन्हें अलग करने के लिए अगर आप आगे पहुंच प्रतिबंधित करना चाहते।

एकीकरण जांच

मैन्युअल परीक्षण के अलावा, फायरबेस प्रमाणीकरण फोन प्रमाणीकरण परीक्षण के लिए एकीकरण परीक्षण लिखने में मदद करने के लिए एपीआई प्रदान करता है। ये एपीआई वेब में रीकैप्चा आवश्यकता और आईओएस में साइलेंट पुश नोटिफिकेशन को अक्षम करके ऐप सत्यापन को अक्षम करते हैं। इससे इन प्रवाहों में स्वचालन परीक्षण संभव हो जाता है और इसे लागू करना आसान हो जाता है। इसके अलावा, वे Android पर तत्काल सत्यापन प्रवाह का परीक्षण करने की क्षमता प्रदान करने में सहायता करते हैं।

IOS पर, appVerificationDisabledForTesting सेटिंग करने के लिए सेट किया जाना है TRUE कॉल करने से पहले verifyPhoneNumber । इसे किसी भी एपीएन टोकन की आवश्यकता के बिना संसाधित किया जाता है या पृष्ठभूमि में मूक पुश अधिसूचनाएं भेजता है, जिससे सिम्युलेटर में परीक्षण करना आसान हो जाता है। यह रीकैप्चा फ़ॉलबैक प्रवाह को भी अक्षम करता है।

ध्यान दें कि जब ऐप सत्यापन अक्षम होता है, तो गैर-काल्पनिक फ़ोन नंबर का उपयोग करने से साइन इन पूरा नहीं हो पाएगा। इस API के साथ केवल काल्पनिक फ़ोन नंबरों का उपयोग किया जा सकता है।

तीव्र

let phoneNumber = "+16505554567"

// This test verification code is specified for the given test phone number in the developer console.
let testVerificationCode = "123456"

Auth.auth().settings.isAppVerificationDisabledForTesting = TRUE
PhoneAuthProvider.provider().verifyPhoneNumber(phoneNumber, uiDelegate:nil) {
                                                            verificationID, error in
    if (error) {
      // Handles error
      self.handleError(error)
      return
    }
    let credential = PhoneAuthProvider.provider().credential(withVerificationID: verificationID ?? "",
                                                               verificationCode: testVerificationCode)
    Auth.auth().signInAndRetrieveData(with: credential) { authData, error in
      if (error) {
        // Handles error
        self.handleError(error)
        return
      }
      _user = authData.user
    }];
}];

उद्देश्य सी

NSString *phoneNumber = @"+16505554567";

// This test verification code is specified for the given test phone number in the developer console.
NSString *testVerificationCode = @"123456";

[FIRAuth auth].settings.appVerificationDisabledForTesting = YES;
[[FIRPhoneAuthProvider provider] verifyPhoneNumber:phoneNumber
                                        completion:^(NSString *_Nullable verificationID,
                                                     NSError *_Nullable error) {
    if (error) {
      // Handles error
      [self handleError:error];
      return;
    }
    FIRAuthCredential *credential =
        [FIRPhoneAuthProvider credentialWithVerificationID:verificationID
                                          verificationCode:testVerificationCode];
    [FIRAuth auth] signInWithAndRetrieveDataWithCredential:credential
                                                completion:^(FIRUser *_Nullable user,
                                                             NSError *_Nullable error) {
      if (error) {
        // Handles error
        [self handleError:error];
        return;
      }
      _user = user;
    }];
}];

परिशिष्ट: बिना तेज गति के फोन साइन-इन का उपयोग करना

फायरबेस प्रमाणीकरण स्वचालित रूप से आपके ऐप के एपीएन टोकन प्राप्त करने के लिए, फायरबेस द्वारा आपके ऐप को भेजे जाने वाले साइलेंट पुश नोटिफिकेशन को संभालने के लिए, और सत्यापन के दौरान रीकैप्चा सत्यापन पृष्ठ से कस्टम स्कीम रीडायरेक्ट को स्वचालित रूप से इंटरसेप्ट करने के लिए स्विज़लिंग विधि का उपयोग करता है।

आप उपयोग swizzling नहीं करना चाहते हैं, तो आप इसे झंडा जोड़कर निष्क्रिय कर सकते हैं FirebaseAppDelegateProxyEnabled को अपने ऐप्लिकेशन के Info.plist फाइल करने के लिए और करने के लिए इसे स्थापित कर NO । नोट करने के लिए इस ध्वज की स्थापना है कि NO भी Firebase क्लाउड संदेश सहित अन्य Firebase उत्पादों के लिए swizzling अक्षम करता है।

यदि आप स्विज़लिंग को अक्षम करते हैं, तो आपको स्पष्ट रूप से एपीएन डिवाइस टोकन, पुश नोटिफिकेशन और कस्टम स्कीम रीडायरेक्ट यूआरएल को फायरबेस प्रमाणीकरण पर पास करना होगा।

APN के उपकरण टोकन प्राप्त करने के लिए लागू application:didRegisterForRemoteNotificationsWithDeviceToken: विधि, और उस में, डिवाइस टोकन को पारित FIRAuth के setAPNSToken:type: विधि।

तीव्र

func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
  // Pass device token to auth
  Auth.auth().setAPNSToken(deviceToken, type: .prod)

  // Further handling of the device token if needed by the app
  // ...
}

उद्देश्य सी

- (void)application:(UIApplication *)application
    didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
  // Pass device token to auth.
  [[FIRAuth auth] setAPNSToken:deviceToken type:FIRAuthAPNSTokenTypeProd];
  // Further handling of the device token if needed by the app.
}

संभाल पुश सूचनाएं, में करने के लिए application:didReceiveRemoteNotification:fetchCompletionHandler: विधि, फोन करके Firebase प्रमाणन संबंधित सूचनाओं के लिए जाँच FIRAuth के canHandleNotification: विधि।

तीव्र

func application(_ application: UIApplication,
    didReceiveRemoteNotification notification: [AnyHashable : Any],
    fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
  if Auth.auth().canHandleNotification(notification) {
    completionHandler(.noData)
    return
  }
  // This notification is not auth related, developer should handle it.
}

उद्देश्य सी

- (void)application:(UIApplication *)application
    didReceiveRemoteNotification:(NSDictionary *)notification
          fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
  // Pass notification to auth and check if they can handle it.
  if ([[FIRAuth auth] canHandleNotification:notification]) {
    completionHandler(UIBackgroundFetchResultNoData);
    return;
  }
  // This notification is not auth related, developer should handle it.
}

कस्टम योजना रीडायरेक्ट URL को संभालने के लिए लागू application:openURL:sourceApplication:annotation: विधि आईओएस 8 वर्ष और उससे, और चलाने वाले उपकरणों के लिए application:openURL:options: आईओएस 9 और नए, और उन्हें में चल रहे उपकरणों के लिए विधि, पारित यूआरएल के लिए FIRAuth के canHandleURL विधि।

तीव्र

// For iOS 9+
func application(_ application: UIApplication, open url: URL,
    options: [UIApplicationOpenURLOptionsKey : Any]) -> Bool {
  if Auth.auth().canHandle(url) {
    return true
  }
  // URL not auth related, developer should handle it.
}

// For iOS 8-
func application(_ application: UIApplication,
                 open url: URL,
                 sourceApplication: String?,
                 annotation: Any) -> Bool {
  if Auth.auth().canHandle(url) {
    Return true
  }
  // URL not auth related, developer should handle it.
}

उद्देश्य सी

// For iOS 9+
- (BOOL)application:(UIApplication *)app
            openURL:(NSURL *)url
            options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options {
  if ([[FIRAuth auth] canHandleURL:url]) {
    return YES;
  }
  // URL not auth related, developer should handle it.
}

// For iOS 8-
- (BOOL)application:(UIApplication *)application
            openURL:(NSURL *)url
  sourceApplication:(NSString *)sourceApplication
         annotation:(id)annotation {
  if ([[FIRAuth auth] canHandleURL:url]) {
    return YES;
  }
  // URL not auth related, developer should handle it.
}

आप SwiftUI या का उपयोग कर रहे हैं UISceneDelegate रीडायरेक्ट URL को संभालने के लिए, को लागू scene:openURLContexts: विधि, और उन में, करने के लिए यूआरएल पारित FIRAuth के canHandleURL विधि।

तीव्र

func scene(_ scene: UIScene, openURLContexts URLContexts: Set<UIOpenURLContext>) {
  for urlContext in URLContexts {
      let url = urlContext.url
      Auth.auth().canHandle(url)
  }
  // URL not auth related, developer should handle it.
}

उद्देश्य सी

- (void)scene:(UIScene *)scene openURLContexts:(NSSet<UIOpenURLContext *> *)URLContexts {
  for (UIOpenURLContext *urlContext in URLContexts) {
    [FIRAuth.auth canHandleURL:urlContext.url];
    // URL not auth related, developer should handle it.
  }
}

अगला कदम

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

  • आपकी ऐप्लिकेशन में, आप से उपयोगकर्ता की मूलभूत जानकारी प्राप्त कर सकते हैं FIRUser वस्तु। देखें उपयोगकर्ताओं का प्रबंधन करें

  • अपने Firebase रीयलटाइम डेटाबेस और मेघ संग्रहण में सुरक्षा नियम , आप प्राप्त कर सकते हैं, जिसमें प्रवेश किया से उपयोगकर्ता की अद्वितीय उपयोगकर्ता ID auth चर, और इसका इस्तेमाल करते हैं क्या डेटा user एक्सेस कर सकते हैं नियंत्रित करने के लिए।

आप उपयोगकर्ताओं द्वारा एकाधिक प्रमाणीकरण प्रदाताओं का उपयोग कर अपने ऐप्लिकेशन में प्रवेश करने के लिए अनुमति दे सकते हैं किसी मौजूदा उपयोगकर्ता खाते के लिए प्रमाणन प्रदाता साख को जोड़ने।

एक उपयोगकर्ता प्रस्थान करने के लिए फोन signOut:

तीव्र

    let firebaseAuth = Auth.auth()
do {
  try firebaseAuth.signOut()
} catch let signOutError as NSError {
  print("Error signing out: %@", signOutError)
}
  

उद्देश्य सी

    NSError *signOutError;
BOOL status = [[FIRAuth auth] signOut:&signOutError];
if (!status) {
  NSLog(@"Error signing out: %@", signOutError);
  return;
}

आप प्रमाणीकरण त्रुटियों की पूरी श्रृंखला के लिए त्रुटि प्रबंधन कोड भी जोड़ना चाह सकते हैं। देखें हैंडल त्रुटियाँ