Memproses login pengguna dengan email menggunakan Identity Platform
Pelajari cara menggunakan Identity Platform untuk memproses login pengguna dengan email dan sandi.
Untuk mengikuti panduan langkah demi langkah tugas ini langsung di konsol Google Cloud , klik Pandu saya:
Sebelum memulai
- 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 column to see whether the list of roles includes the required roles.
Grant the roles
-
In the Google Cloud console, go to the IAM page.
Buka IAM - Pilih project.
- Klik Berikan akses.
-
Di kolom New principals, masukkan ID pengguna Anda. Ini biasanya adalah alamat email untuk Akun Google.
- Di daftar Pilih peran, pilih peran.
- Untuk memberikan peran tambahan, klik Tambahkan peran lain, lalu tambahkan setiap peran tambahan.
- Klik Simpan.
-
-
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 column to see whether the list of roles includes the required roles.
Grant the roles
-
In the Google Cloud console, go to the IAM page.
Buka IAM - Pilih project.
- Klik Berikan akses.
-
Di kolom New principals, masukkan ID pengguna Anda. Ini biasanya adalah alamat email untuk Akun Google.
- Di daftar Pilih peran, pilih peran.
- Untuk memberikan peran tambahan, klik Tambahkan peran lain, lalu tambahkan setiap peran tambahan.
- Klik Simpan.
-
Aktifkan Identity Platform
Di konsol Google Cloud , buka halaman Identity Platform di Cloud Marketplace.
Klik Aktifkan Identity Platform.
Mengonfigurasi login dengan email
Buka halaman Penyedia Identitas.
Di halaman Penyedia Identitas, klik Tambahkan penyedia.
Di daftar Pilih penyedia, pilih
Email/Sandi.Klik tombol Aktifkan ke aktif.
Untuk menyimpan setelan penyedia, klik Simpan.
Membuat pengguna
Di konsol Google Cloud , buka halaman Users.
Klik Tambahkan pengguna.
Di kolom Email, masukkan email dan sandi. Perhatikan kedua nilai ini karena Anda memerlukannya pada langkah berikutnya.
Untuk menambahkan pengguna, klik Tambahkan. Pengguna baru tercantum di halaman Pengguna.
Memproses login pengguna
Langkah-langkah untuk memproses login pengguna bervariasi bergantung pada versi SDK yang digunakan aplikasi Anda. Pastikan Anda mengikuti langkah-langkah yang benar untuk aplikasi Anda.
SDK v9 (modular)
Menginstal SDK dan melakukan inisialisasi Firebase
Firebase JS SDK versi 9 menggunakan format Modul JavaScript.
Alur kerja ini menggunakan npm dan memerlukan pemaket modul atau alat framework JavaScript karena SDK v9 dioptimalkan agar dapat digunakan dengan pemaket modul untuk menghapus kode yang tidak digunakan (tree-shaking) dan mengurangi ukuran SDK.
Untuk menggunakan SDK v9, lakukan langkah-langkah berikut:
Dari direktori project, instal Firebase menggunakan npm:
npm install firebase
Inisialisasi Firebase di aplikasi Anda dan buat objek Aplikasi Firebase:
import { initializeApp } from 'firebase/app'; const firebaseConfig = { apiKey: "API_KEY", authDomain: "AUTH_DOMAIN" }; const app = initializeApp(firebaseConfig);
Ganti kode berikut:
API_KEY
:apiKey
project Firebase Anda.AUTH_DOMAIN
:authDomain
project Firebase Anda.
Anda dapat menemukan nilai ini dari konfigurasi project Firebase aplikasi Anda.
Aplikasi Firebase adalah objek mirip container yang menyimpan konfigurasi umum dan membagikan autentikasi di berbagai layanan Firebase. Setelah menginisialisasi objek Aplikasi Firebase dalam kode, Anda dapat menambahkan dan mulai menggunakan layanan Firebase.
Mengakses Identity Platform di JavaScript
Setelah menginisialisasi Firebase SDK, Anda dapat menggunakannya di mana saja di aplikasi. Misalnya, berikut adalah aplikasi yang mencoba login pengguna hardcode dan menampilkan hasilnya di halaman 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;
});
}
Ganti kode berikut:
API_KEY
:apiKey
project Firebase Anda.AUTH_DOMAIN
:authDomain
project Firebase Anda.EMAIL_ID
: alamat email pengguna yang Anda buat sebelumnya dalam panduan ini.PASSWORD
: sandi pengguna yang Anda buat sebelumnya dalam panduan ini.
Menggunakan bundler modul untuk mengurangi ukuran
Firebase Web SDK dirancang agar dapat digunakan dengan pemaket modul guna menghapus kode yang tidak digunakan (tree-shaking). Kami sangat merekomendasikan pendekatan ini untuk aplikasi produksi. Alat seperti Angular CLI, Next.js, Vue CLI, atau Create React App otomatis menangani pemaketan modul untuk library yang diinstal melalui npm dan diimpor ke codebase Anda.
Misalnya, Anda dapat menggunakan Webpack
untuk membuat folder dist
yang berisi paket aplikasi dan kode dependensi Anda. Lihat Menggunakan pemaket modul dengan Firebase untuk mengetahui informasi selengkapnya.
Mengimpor JavaScript ke halaman
Membuat file baru bernama
index.html
.Tambahkan dua penampung HTML dasar dan impor js yang dipaketkan.
<script defer src="js/bundled.js"></script> <div>Identity Platform Quickstart</div> <div id="message">Loading...</div>
Luncurkan
index.html
di browser web Anda. Pesan selamat datang yang menampilkan email pengguna Anda akan muncul.
SDK v8 (lama)
Membuat halaman web
Di komputer lokal, buat file baru bernama
index.html
.Di file HTML, tambahkan dua penampung HTML:
<div>Identity Platform Quickstart</div> <div id="message">Loading...</div>
Melakukan inisialisasi SDK klien Identity Platform dengan kunci API Anda
Di konsol Google Cloud , buka halaman Penyedia Identitas.
Klik
Detail penyiapan aplikasi .Salin kode inisialisasi ke
index.html
.
Memproses login pengguna
Untuk memproses login pengguna, salin kode berikut ke
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>
Kode ini memanggil
signInWithEmailAndPassword()
, lalu memproses hasilnya dengan callbackonAuthStateChanged()
.Ganti kode berikut:
- EMAIL_ID: email untuk pengguna yang Anda buat sebelumnya
- PASSWORD: sandi untuk pengguna yang Anda buat sebelumnya
Buka
index.html
di browser web Anda. Pesan selamat datang yang menampilkan email pengguna Anda akan muncul.
Untuk mengetahui informasi selengkapnya tentang batas Identity Platform lainnya, lihat Kuota dan batas.
Pembersihan
Agar akun Google Cloud Anda tidak dikenai biaya untuk resource yang digunakan di halaman ini, ikuti langkah-langkah berikut.
Menghapus penyedia dan pengguna
Jika Anda menggunakan project Google Cloud yang sudah ada, hapus penyedia dan pengguna yang Anda buat untuk menghindari tagihan pada akun Anda:
Di konsol Google Cloud , buka halaman Penyedia Identitas.
Untuk menghapus penyedia, klik
Hapus di samping nama penyedia. Untuk mengonfirmasi, klik Hapus.Di konsol Google Cloud , buka halaman Users.
Untuk menghapus pengguna yang Anda buat, klik
Hapus di samping nama pengguna. Untuk mengonfirmasi, klik Hapus.
Menghapus project
Cara termudah untuk menghilangkan penagihan adalah dengan menghapus project yang Anda buat untuk tutorial.
Untuk menghapus project:
- 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.
Langkah selanjutnya
Dalam aplikasi yang sebenarnya, pengguna akan mendaftar menggunakan halaman pendaftaran khusus, lalu login dengan memasukkan email dan sandi mereka. Identity Platform menawarkan UI autentikasi bawaan yang dapat Anda gunakan untuk halaman ini, atau Anda dapat membuat UI Anda sendiri. Anda mungkin juga ingin mendukung metode login tambahan, seperti penyedia media sosial (seperti Facebook atau Google), nomor telepon, OIDC, atau SAML.
Pelajari lebih lanjut hal berikut:
Login pengguna dengan JavaScript, Android, iOS, C++, atau Unity.
Migrasi pengguna dari aplikasi yang ada ke Identity Platform.