Firebase Summit で発表されたすべての情報をご覧ください。Firebase を使用してアプリ開発を加速し、自信を持ってアプリを実行する方法を紹介しています。詳細

AndroidでFirebaseを使用して匿名で認証する

コレクションでコンテンツを整理 必要に応じて、コンテンツの保存と分類を行います。

Firebase Authentication を使用して一時的な匿名アカウントを作成し、Firebase で認証するために使用できます。これらの一時的な匿名アカウントを使用して、アプリにまだサインアップしていないユーザーが、セキュリティ ルールによって保護されたデータを操作できるようにすることができます。匿名ユーザーがアプリにサインアップすることを決定した場合、サインイン資格情報を匿名アカウントにリンクして、今後のセッションで保護されたデータを引き続き使用できるようにすることができます。

あなたが始める前に

  1. まだ行っていない場合は、 Firebase を Android プロジェクトに追加します
  2. モジュール (アプリ レベル) の Gradle ファイル(通常は<project>/<app-module>/build.gradle ) で、Firebase Authentication Android ライブラリの依存関係を追加します。ライブラリのバージョン管理には、 Firebase Android BoMを使用することをお勧めします。

    Java

    dependencies {
        // Import the BoM for the Firebase platform
        implementation platform('com.google.firebase:firebase-bom:31.1.0')
    
        // Add the dependency for the Firebase Authentication library
        // When using the BoM, you don't specify versions in Firebase library dependencies
        implementation 'com.google.firebase:firebase-auth'
    }
    

    Firebase Android BoMを使用すると、アプリは常に互換性のあるバージョンの Firebase Android ライブラリを使用します。

    (代替) BoM を使用せずに Firebase ライブラリの依存関係を追加する

    Firebase BoM を使用しないことを選択した場合は、依存関係の行で各 Firebase ライブラリ バージョンを指定する必要があります。

    アプリで複数のFirebase ライブラリを使用する場合は、BoM を使用してライブラリ バージョンを管理することを強くお勧めします。これにより、すべてのバージョンに互換性が確保されます。

    dependencies {
        // Add the dependency for the Firebase Authentication library
        // When NOT using the BoM, you must specify versions in Firebase library dependencies
        implementation 'com.google.firebase:firebase-auth:21.1.0'
    }
    

    Kotlin+KTX

    dependencies {
        // Import the BoM for the Firebase platform
        implementation platform('com.google.firebase:firebase-bom:31.1.0')
    
        // Add the dependency for the Firebase Authentication library
        // When using the BoM, you don't specify versions in Firebase library dependencies
        implementation 'com.google.firebase:firebase-auth-ktx'
    }
    

    Firebase Android BoMを使用すると、アプリは常に互換性のあるバージョンの Firebase Android ライブラリを使用します。

    (代替) BoM を使用せずに Firebase ライブラリの依存関係を追加する

    Firebase BoM を使用しないことを選択した場合は、依存関係の行で各 Firebase ライブラリ バージョンを指定する必要があります。

    アプリで複数のFirebase ライブラリを使用する場合は、BoM を使用してライブラリ バージョンを管理することを強くお勧めします。これにより、すべてのバージョンに互換性が確保されます。

    dependencies {
        // Add the dependency for the Firebase Authentication library
        // When NOT using the BoM, you must specify versions in Firebase library dependencies
        implementation 'com.google.firebase:firebase-auth-ktx:21.1.0'
    }
    
  3. アプリを Firebase プロジェクトにまだ接続していない場合は、 Firebase コンソールから接続します。
  4. 匿名認証を有効にします。
    1. Firebase コンソールで、 Authセクションを開きます。
    2. [サインイン方法]ページで、匿名サインイン方法を有効にします。
    3. オプション: プロジェクトをFirebase Authentication with Identity Platformにアップグレードした場合は、自動クリーンアップを有効にできます。この設定を有効にすると、30 日以上経過した匿名アカウントが自動的に削除されます。自動クリーンアップが有効になっているプロジェクトでは、匿名認証は使用制限または請求クォータにカウントされなくなります。自動クリーンアップを参照してください。

Firebase で匿名で認証する

サインアウトしたユーザーが Firebase での認証を必要とするアプリ機能を使用する場合は、次の手順を実行してユーザーを匿名でサインインします。

  1. アクティビティのonCreateメソッドで、 FirebaseAuthオブジェクトの共有インスタンスを取得します。

    Java

    private FirebaseAuth mAuth;
    // ...
    // Initialize Firebase Auth
    mAuth = FirebaseAuth.getInstance();

    Kotlin+KTX

    private lateinit var auth: FirebaseAuth
    // ...
    // Initialize Firebase Auth
    auth = Firebase.auth
  2. アクティビティを初期化するときに、ユーザーが現在サインインしているかどうかを確認します。

    Java

    @Override
    public void onStart() {
        super.onStart();
        // Check if user is signed in (non-null) and update UI accordingly.
        FirebaseUser currentUser = mAuth.getCurrentUser();
        updateUI(currentUser);
    }

    Kotlin+KTX

    public override fun onStart() {
        super.onStart()
        // Check if user is signed in (non-null) and update UI accordingly.
        val currentUser = auth.currentUser
        updateUI(currentUser)
    }
  3. 最後に、 signInAnonymouslyを呼び出して、匿名ユーザーとしてサインインします。

    Java

    mAuth.signInAnonymously()
            .addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
                @Override
                public void onComplete(@NonNull Task<AuthResult> task) {
                    if (task.isSuccessful()) {
                        // Sign in success, update UI with the signed-in user's information
                        Log.d(TAG, "signInAnonymously:success");
                        FirebaseUser user = mAuth.getCurrentUser();
                        updateUI(user);
                    } else {
                        // If sign in fails, display a message to the user.
                        Log.w(TAG, "signInAnonymously:failure", task.getException());
                        Toast.makeText(AnonymousAuthActivity.this, "Authentication failed.",
                                Toast.LENGTH_SHORT).show();
                        updateUI(null);
                    }
                }
            });

    Kotlin+KTX

    auth.signInAnonymously()
            .addOnCompleteListener(this) { task ->
                if (task.isSuccessful) {
                    // Sign in success, update UI with the signed-in user's information
                    Log.d(TAG, "signInAnonymously:success")
                    val user = auth.currentUser
                    updateUI(user)
                } else {
                    // If sign in fails, display a message to the user.
                    Log.w(TAG, "signInAnonymously:failure", task.exception)
                    Toast.makeText(baseContext, "Authentication failed.",
                            Toast.LENGTH_SHORT).show()
                    updateUI(null)
                }
            }
    サインインが成功した場合は、 getCurrentUserメソッドを使用してユーザーのアカウント データを取得できます。

匿名アカウントを永久アカウントに変換する

匿名ユーザーがアプリにサインアップするとき、新しいアカウントで作業を継続できるようにすることができます。たとえば、ユーザーがサインアップする前にショッピング カートに追加したアイテムを、新しいアカウントで利用できるようにすることができます。アカウントのショッピング カート。これを行うには、次の手順を実行します。

  1. ユーザーがサインアップしたら、 FirebaseAuth.signInWithメソッドの 1 つを呼び出すまで、ユーザーの認証プロバイダーのサインイン フローを完了します。たとえば、ユーザーの Google ID トークン、Facebook アクセス トークン、またはメール アドレスとパスワードを取得します。
  2. 新しい認証プロバイダーのAuthCredentialを取得します。

    Google サインイン

    Java

    AuthCredential credential = GoogleAuthProvider.getCredential(googleIdToken, null);

    Kotlin+KTX

    val credential = GoogleAuthProvider.getCredential(googleIdToken, null)
    フェイスブックログイン

    Java

    AuthCredential credential = FacebookAuthProvider.getCredential(token.getToken());

    Kotlin+KTX

    val credential = FacebookAuthProvider.getCredential(token.token)
    メールパスワードサインイン

    Java

    AuthCredential credential = EmailAuthProvider.getCredential(email, password);

    Kotlin+KTX

    val credential = EmailAuthProvider.getCredential(email, password)
  3. AuthCredentialオブジェクトをサインイン ユーザーのlinkWithCredentialメソッドに渡します。

    Java

    mAuth.getCurrentUser().linkWithCredential(credential)
            .addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
                @Override
                public void onComplete(@NonNull Task<AuthResult> task) {
                    if (task.isSuccessful()) {
                        Log.d(TAG, "linkWithCredential:success");
                        FirebaseUser user = task.getResult().getUser();
                        updateUI(user);
                    } else {
                        Log.w(TAG, "linkWithCredential:failure", task.getException());
                        Toast.makeText(AnonymousAuthActivity.this, "Authentication failed.",
                                Toast.LENGTH_SHORT).show();
                        updateUI(null);
                    }
                }
            });

    Kotlin+KTX

    auth.currentUser!!.linkWithCredential(credential)
            .addOnCompleteListener(this) { task ->
                if (task.isSuccessful) {
                    Log.d(TAG, "linkWithCredential:success")
                    val user = task.result?.user
                    updateUI(user)
                } else {
                    Log.w(TAG, "linkWithCredential:failure", task.exception)
                    Toast.makeText(baseContext, "Authentication failed.",
                            Toast.LENGTH_SHORT).show()
                    updateUI(null)
                }
            }

linkWithCredentialの呼び出しが成功すると、ユーザーの新しいアカウントは匿名アカウントの Firebase データにアクセスできます。

自動クリーンアップ

プロジェクトをFirebase Authentication with Identity Platformにアップグレードした場合は、Firebase コンソールで自動クリーンアップを有効にできます。この機能を有効にすると、Firebase は 30 日以上経過した匿名アカウントを自動的に削除します。自動クリーンアップが有効になっているプロジェクトでは、匿名認証は使用制限や課金クォータにカウントされません。

  • 自動クリーンアップを有効にした後に作成された匿名アカウントは、作成後 30 日後に自動的に削除される可能性があります。
  • 自動クリーンアップを有効にする前に作成された匿名アカウントは、自動クリーンアップを有効にしてから 30 日後に自動削除の対象となります。
  • 自動クリーンアップをオフにすると、削除予定の匿名アカウントは削除予定のままになります。これらのアカウントは、使用制限や請求割り当てにはカウントされません。
  • 匿名アカウントを任意のサインイン方法にリンクして「アップグレード」した場合、アカウントは自動的に削除されません。

この機能を有効にする前に影響を受けるユーザーの数を確認したい場合で、プロジェクトをFirebase Authentication with Identity Platformにアップグレードした場合は、 Cloud Loggingis_anonでフィルタリングできます。

次のステップ

ユーザーが Firebase で認証できるようになったので、 Firebase ルールを使用して、Firebase データベース内のデータへのアクセスを制御できます。