C++'yı Kullanarak Firebase ile Anonim Kimlik Doğrulama

Geçici anonim hesaplar oluşturmak ve kullanmak için Firebase Authentication kullanabilirsiniz Firebase ile kimlik doğrulama. Bu geçici anonim hesaplar şu amaçlarla kullanılabilir: henüz uygulamanıza kaydolmamış kullanıcıların verilerle korunan verilerle çalışmasını sağlar izin verir. Anonim bir kullanıcı uygulamanıza kaydolmaya karar verirse: oturum açma kimlik bilgilerini anonimleştirerek koruma altındaki verilerle çalışmaya devam edebilmeleri için oturum açın.

Başlamadan önce

  1. Firebase'i C++ kullanıcılarınıza ekleyin inceleyebilirsiniz.
  2. Uygulamanızı henüz Firebase projenize bağlamadıysanız bunu Firebase konsolunda bulabilirsiniz.
  3. Anonim kimlik doğrulamayı etkinleştir:
    1. Firebase konsolunda Auth bölümünü açın.
    2. Sign-in Methods (Oturum Açma Yöntemleri) sayfasında, Anonymous (Anonim) oturum açma yöntemini kullanabilirsiniz.
    3. İsteğe bağlı: Projenizi Firebase Authentication with Identity Platform, otomatik temizlemeyi etkinleştirebilirsiniz. Zaman Bu ayarı etkinleştirdiğinizde, 30 günden daha eski anonim hesaplar otomatik olarak silindi. Otomatik temizlemenin etkin olduğu projelerde anonim kimlik doğrulama kullanım sınırlarına veya faturalandırma kotalarına dahil edilir. Görüntüleyin Otomatik temizlik.

Firebase ile anonim olarak kimlik doğrulama

Oturumu kapalı olan bir kullanıcı, Firebase'de, aşağıdaki adımları uygulayarak kullanıcının anonim olarak oturum açmasını sağlayın:

Auth sınıfı, tüm API çağrılarına yönelik ağ geçididir.
  1. Auth ve Uygulama başlığı dosyalarını ekleyin:
    #include "firebase/app.h"
    #include "firebase/auth.h"
    
    .
  2. Başlatma kodunuzda bir firebase::App sınıfı.
    #if defined(__ANDROID__)
      firebase::App* app =
          firebase::App::Create(firebase::AppOptions(), my_jni_env, my_activity);
    #else
      firebase::App* app = firebase::App::Create(firebase::AppOptions());
    #endif  // defined(__ANDROID__)
    
  3. firebase::App için firebase::auth::Auth sınıfını edinin. App ile Auth arasında bire bir eşleme var.
    firebase::auth::Auth* auth = firebase::auth::Auth::GetAuth(app);
    
  • Auth::SignInAnonymously numaralı telefonu arayın.
    firebase::Future<firebase::auth::AuthResult> result =
        auth->SignInAnonymously();
    
  • Programınızda düzenli olarak devam eden bir güncelleme döngüsü varsa (örneğin, 30 veya 60'ta) veya saniyede bir), sonuçları güncelleme başına bir defa Auth::SignInAnonymouslyLastResult:
    firebase::Future<firebase::auth::AuthResult> result =
        auth->SignInAnonymouslyLastResult();
    if (result.status() == firebase::kFutureStatusComplete) {
      if (result.error() == firebase::auth::kAuthErrorNone) {
        firebase::auth::AuthResult auth_result = *result.result();
        printf("Sign in succeeded for `%s`\n",
               auth_result.user.display_name().c_str());
      } else {
        printf("Sign in failed with error '%s'\n", result.error_message());
      }
    }
    
    Programınız etkinliklere dayalıysa bir geri çağırmanın kaydedileceği Gelecek.
  • Anonim bir hesabı kalıcı hesaba dönüştürme

    Anonim bir kullanıcı, uygulamanıza kaydolduğunda bu kişilerin yeni hesabıyla çalışmaya devam edebilir. Örneğin, Kullanıcının kaydolmadan önce alışveriş sepetine eklediği öğeleri yapma Yeni hesabının alışveriş sepetinde bulunabilir. Bunun için aşağıdaki adımları uygulayın: için şu adımları izleyin:

    1. Kullanıcı kaydolduğunda, kullanıcının en az bir veya daha fazla yetkili olan bir Auth::SignInWith yöntem. Örneğin, kullanıcının Google kimliği jetonunu alın. Facebook erişim jetonu veya e-posta adresi ve şifre.
    2. Yeni kimlik doğrulama sağlayıcı için bir auth::Credential alın:

      Google ile Oturum Açma
      firebase::auth::Credential credential =
          firebase::auth::GoogleAuthProvider::GetCredential(google_id_token,
                                                            nullptr);
      
      Facebook'a Giriş
      firebase::auth::Credential credential =
          firebase::auth::FacebookAuthProvider::GetCredential(access_token);
      
      E-posta şifresiyle oturum açma
      firebase::auth::Credential credential =
          firebase::auth::EmailAuthProvider::GetCredential(email, password);
      
    3. auth::Credential nesnesini oturum açan kullanıcının cihazına iletin LinkWithCredential yöntemi:

      // Link the new credential to the currently active user.
      firebase::auth::User current_user = auth->current_user();
      firebase::Future<firebase::auth::AuthResult> result =
          current_user.LinkWithCredential(credential);
      

    LinkWithCredential çağrısı başarılı olursa kullanıcının yeni hesabı: Anonim hesabın Firebase verilerine erişebilir.

    Otomatik temizleme

    Projenizi Firebase Authentication with Identity Platform sürümüne yükselttiyseniz şunları yapabilirsiniz: Firebase konsolunda otomatik temizlemeyi etkinleştirin. Bu özelliği etkinleştirdiğinizde Firebase'in 30 günden daha eski anonim hesapları otomatik olarak silmesine olanak tanır. Otomatik kullanılan projelerde temizlik etkin olduğunda, anonim kimlik doğrulama kullanım sınırlarına veya faturalandırma kotalarına dahil edilmez.

    • Otomatik temizleme özelliği etkinleştirildikten sonra oluşturulan anonim hesaplar otomatik olarak silinebilir oluşturulduktan 30 gün sonra herhangi bir zamanda silinir.
    • Mevcut anonim hesaplar, 30 gün sonra otomatik olarak silinebilir. etkinleştirebilirsiniz.
    • Otomatik temizlemeyi kapatırsanız silinmesi planlanan tüm anonim hesaplar kalır silinmesi planlandı.
    • "Yükseltme" seçeneğini belirlerseniz herhangi bir oturum açma yöntemine bağlayarak anonim bir hesap üzerinde çalışırsanız otomatik olarak silinmez.

    Bu özelliği etkinleştirmeden önce kaç kullanıcının etkileneceğini görmek istiyorsanız ve projenizi Firebase Authentication with Identity Platform sürümüne yükselttiyseniz şuna göre filtreleyebilirsiniz: Cloud'da is_anon Günlük Kaydı.

    Sonraki adımlar

    Kullanıcılar artık Firebase ile kimlik doğrulaması yapabildiğine göre Firebase veritabanınızdaki verileri kullanarak Firebase kuralları.