Fazer login de um usuário com um e-mail usando o Identity Platform
Saiba como usar o Identity Platform para fazer login de um usuário com um e-mail e uma senha.
Para seguir as instruções passo a passo desta tarefa diretamente no console do Google Cloud, clique em Orientação:
Antes de começar
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Make sure that you have the following role or roles on the project: Identity Platform Admin, Service Usage Admin
Check for the roles
-
In the Google Cloud console, go to the IAM page.
Go to IAM - Select the project.
-
In the Principal column, find all rows that identify you or a group that you're included in. To learn which groups you're included in, contact your administrator.
- For all rows that specify or include you, check the Role colunn to see whether the list of roles includes the required roles.
Grant the roles
-
In the Google Cloud console, go to the IAM page.
Acessar o IAM - Selecionar um projeto.
- Clique em CONCEDER ACESSO.
-
No campo Novos principais, insira seu identificador de usuário. Normalmente, é o endereço de e-mail de uma Conta do Google.
- Na lista Selecionar um papel, escolha um.
- Para conceder outros papéis, clique em Adicionar outro papel e adicione cada papel adicional.
- Clique em Salvar.
-
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Make sure that you have the following role or roles on the project: Identity Platform Admin, Service Usage Admin
Check for the roles
-
In the Google Cloud console, go to the IAM page.
Go to IAM - Select the project.
-
In the Principal column, find all rows that identify you or a group that you're included in. To learn which groups you're included in, contact your administrator.
- For all rows that specify or include you, check the Role colunn to see whether the list of roles includes the required roles.
Grant the roles
-
In the Google Cloud console, go to the IAM page.
Acessar o IAM - Selecionar um projeto.
- Clique em CONCEDER ACESSO.
-
No campo Novos principais, insira seu identificador de usuário. Normalmente, é o endereço de e-mail de uma Conta do Google.
- Na lista Selecionar um papel, escolha um.
- Para conceder outros papéis, clique em Adicionar outro papel e adicione cada papel adicional.
- Clique em Salvar.
-
Ativar o Identity Platform
No console do Google Cloud, acesse a página Identity Platform no Marketplace do Cloud.
Clique em Ativar Identity Platform.
Configurar um login por e-mail
Acesse a página Provedores de identidade.
Na página Provedores de identidade, clique em Adicionar um provedor.
Na lista Selecionar um provedor, selecione
E-mail/senha.Clique no botão Ativado para ativar.
Para salvar as configurações do provedor, clique em Salvar.
Criar um usuário
No console do Google Cloud, acesse a página Usuários.
Clique em Adicionar usuário.
No campo E-mail, digite um e-mail e uma senha. Anote esses dois valores, porque você vai precisar deles em uma etapa posterior.
Para adicionar o usuário, clique em Adicionar. O novo usuário é listado na página Usuários.
Fazer o login do usuário
As etapas para fazer login do usuário variam de acordo com a versão do SDK que o app está usando. Verifique se você está seguindo as etapas corretas para o aplicativo.
SDK v9 (modular)
Instalar o SDK e inicializar o Firebase
A versão 9 do SDK do Firebase para JavaScript usa o formato de módulo JavaScript.
Esse fluxo de trabalho usa npm e requer bundlers de módulos ou ferramentas de framework de JavaScript porque o SDK v9 é otimizado para funcionar com bundlers de módulos para eliminar código não utilizado (tree shaking) e diminuir o tamanho do SDK.
Para usar o SDK v9, siga estas etapas:
No diretório do projeto, instale o Firebase usando o npm:
npm install firebase
Inicialize o Firebase no app e crie um objeto do app Firebase:
import { initializeApp } from 'firebase/app'; const firebaseConfig = { apiKey: "API_KEY", authDomain: "AUTH_DOMAIN" }; const app = initializeApp(firebaseConfig);
Substitua:
API_KEY
: oapiKey
do seu projeto do Firebase.AUTH_DOMAIN
: oauthDomain
do seu projeto do Firebase.
Você pode encontrar esses valores na configuração do projeto do Firebase do seu app.
Um app Firebase é um objeto semelhante a um contêiner que armazena configurações comuns e compartilha a autenticação nos serviços do Firebase. Depois de inicializar um objeto do app Firebase no código, é possível adicionar e começar a usar os serviços do Firebase.
Acessar o Identity Platform no seu JavaScript
Agora que você inicializou o SDK do Firebase, é possível usá-lo em qualquer lugar do app. Por exemplo, aqui está um app que tenta fazer login em um usuário fixado e mostrar o resultado em uma página da Web.
import { initializeApp } from 'firebase/app';
import {
onAuthStateChanged,
signInWithEmailAndPassword,
getAuth
} from 'firebase/auth';
const firebaseConfig = {
apiKey: "API_KEY",
authDomain: "AUTH_DOMAIN"
};
const app = initializeApp(firebaseConfig);
const auth = getAuth(app, {/* extra options */ });
document.addEventListener("DOMContentLoaded", () => {
onAuthStateChanged(auth, (user) => {
if (user) {
document.getElementById("message").innerHTML = "Welcome, " + user.email;
}
else {
document.getElementById("message").innerHTML = "No user signed in.";
}
});
signIn();
});
function signIn() {
const email = "EMAIL_ID";
const password = "PASSWORD";
signInWithEmailAndPassword(auth, email, password)
.catch((error) => {
document.getElementById("message").innerHTML = error.message;
});
}
Substitua:
API_KEY
: oapiKey
do seu projeto do Firebase.AUTH_DOMAIN
: oauthDomain
do seu projeto do Firebase.EMAIL_ID
: o endereço de e-mail do usuário que você criou anteriormente neste guia.PASSWORD
: a senha do usuário que você criou anteriormente neste guia.
Usar um bundler de módulo para redução de tamanho
O SDK da Web do Firebase foi projetado para funcionar com bundlers de módulos para remover qualquer código não utilizado (tree shaking). É altamente recomendável usar essa abordagem para apps de produção. Ferramentas como a Angular CLI, Next.js, Vue CLI ou Create React App processam automaticamente o empacotamento de módulos para bibliotecas instaladas pelo npm e importadas para a base de código.
Por exemplo, é possível usar o Webpack
para gerar uma pasta dist
que contém o aplicativo e o código de dependência em pacote. Consulte Como usar os bundlers de módulo com o Firebase
para mais informações.
Importar o JavaScript para a página
Crie um novo arquivo denominado
index.html
.Adicione dois contêineres HTML básicos e importe o js agrupado.
<script defer src="js/bundled.js"></script> <div>Identity Platform Quickstart</div> <div id="message">Loading...</div>
Abra
index.html
em seu navegador da Web. Uma mensagem de recepção com o e-mail do usuário será exibida.
SDK v8 (legado)
Criar uma página da Web
Na sua máquina local, crie um arquivo com o nome
index.html
.No arquivo HTML, adicione dois contêineres HTML:
<div>Identity Platform Quickstart</div> <div id="message">Loading...</div>
Inicializar o SDK de cliente do Identity Platform com sua chave de API
No console do Google Cloud, acesse a página Provedores de identidade.
Clique em
Detalhes da configuração do aplicativo .Copie o código de inicialização para
index.html
.
Fazer o login do usuário
Para fazer login do usuário, copie o seguinte código em
index.html
:<script> var email = "EMAIL_ID"; var password = "PASSWORD"; firebase.auth().onAuthStateChanged(function(user) { if (user) { document.getElementById("message").innerHTML = "Welcome, " + user.email; } else { document.getElementById("message").innerHTML = "No user signed in."; } }); firebase.auth().signInWithEmailAndPassword(email, password).catch(function(error) { document.getElementById("message").innerHTML = error.message; }); </script>
Esse código chama
signInWithEmailAndPassword()
e processa o resultado com o callbackonAuthStateChanged()
.Substitua:
- EMAIL_ID: o e-mail do usuário que você criou anteriormente
- PASSWORD: a senha do usuário que você criou anteriormente
Abra
index.html
no navegador da Web. Uma mensagem de boas-vindas exibindo o e-mail do usuário será exibida.
Para mais informações sobre outros limites do Identity Platform, consulte Cotas e limites.
Limpar
Para evitar cobranças na conta do Google Cloud pelos recursos usados nesta página, siga estas etapas.
Excluir o provedor e o usuário
Se você usou um projeto do Google Cloud, exclua o provedor e o usuário criados para evitar cobranças na sua conta:
No console do Google Cloud, acesse a página Provedores de identidade.
Para excluir o provedor, clique em
Excluir ao lado do nome dele. Para confirmar, clique em Excluir.No console do Google Cloud, acesse a página Usuários.
Para excluir o usuário que você criou, clique em
Excluir ao lado do nome do usuário. Para confirmar, clique em Excluir.
Exclua o projeto
O jeito mais fácil de evitar cobranças é excluindo o projeto que você criou para o tutorial.
Para excluir o projeto:
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
A seguir
Em um app real, seus usuários se inscreveriam usando uma página de registro dedicada e fariam login inserindo os e-mails e senhas. O Identity Platform oferece uma IU de autenticação pré-criada que pode ser usada para essas páginas. Outra opção é criar sua própria. Talvez você queira oferecer suporte a outros métodos de login, como provedores sociais (como Facebook ou Google), números de telefone, OIDC ou SAML.
Saiba mais sobre estes assuntos:
Faça login de usuários com JavaScript, Android, iOS, C++ ou Unity.
Migrar usuários do seu app atual para o Identity Platform.