Autenticar anonimamente com o Firebase no Android

Use o Firebase Authentication para criar e usar contas anônimas temporárias e fazer a autenticação no Firebase. Com essas contas, os usuários que ainda não se inscreveram no seu app podem trabalhar com os dados protegidos pelas regras de segurança. Se um usuário anônimo se inscrever, vincule as credenciais de login à conta anônima para que ele continue trabalhando com os dados protegidos em sessões posteriores.

Antes de começar

  1. Adicione o Firebase ao seu projeto do Android.
  2. Adicione a dependência do Firebase Authentication ao seu arquivo build.gradle de nível de aplicativo:
    implementation 'com.google.firebase:firebase-auth:16.0.3'
  3. Caso você ainda não tenha conectado o aplicativo ao seu projeto do Firebase, faça isso no Firebase console.
  4. Ative a autenticação anônima:
    1. No Console do Firebase, abra a seção Autenticação.
    2. Na página Métodos de login, ative o método de login Anônimo.

Fazer a autenticação anônima no Firebase

Quando um usuário não conectado usar um recurso do app que exija autenticação com o Firebase, conecte esse usuário anonimamente executando as seguintes etapas:

  1. No método onCreate da atividade, receba a instância compartilhada do objeto FirebaseAuth:
    private FirebaseAuth mAuth;
    // ...
    mAuth = FirebaseAuth.getInstance();
    
  2. Ao inicializar sua atividade, verifique se o usuário está conectado no momento:
    @Override
    public void onStart() {
        super.onStart();
        // Check if user is signed in (non-null) and update UI accordingly.
        FirebaseUser currentUser = mAuth.getCurrentUser();
        updateUI(currentUser);
    }
    
  3. Por fim, chame signInAnonymously para fazer login como usuário anônimo:
    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);
                    }
    
                    // ...
                }
            });
    
    Se o login tiver sucesso, você poderá usar o método getCurrentUser para coletar os dados da conta do usuário.

Converter uma conta anônima em permanente

Quando um usuário anônimo se inscreve no seu app, ele pode continuar trabalhando com a nova conta. Por exemplo, você pode deixar no carrinho de compras dessa conta os itens adicionados antes da inscrição. Para isso, realize as seguintes etapas:

  1. Quando o usuário se inscrever, conclua o fluxo de login para o provedor de autenticação até a chamada de um dos métodos FirebaseAuth.signInWith, mas sem incluir essa etapa. Por exemplo, receba o token de código do Google, o token de acesso do Facebook ou o endereço de e-mail e a senha do usuário.
  2. Crie uma AuthCredential para o novo provedor de autenticação:

    Login do Google
    AuthCredential credential = GoogleAuthProvider.getCredential(googleIdToken, null);
    
    Login do Facebook
    AuthCredential credential = FacebookAuthProvider.getCredential(token.getToken());
    
    Login com e-mail/senha
    AuthCredential credential = EmailAuthProvider.getCredential(email, password);
    
  3. Transmita o objeto AuthCredential para o método linkWithCredential do usuário conectado:

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

Se a chamada para linkWithCredential tiver sucesso, a nova conta do usuário poderá acessar os dados do Firebase da conta anônima.

Próximas etapas

Agora que os usuários podem se autenticar com o Firebase, use as regras do Firebase para controlar os respectivos acessos ao banco de dados.

Enviar comentários sobre…

Precisa de ajuda? Acesse nossa página de suporte.