借助 Firebase Authentication,您可以让用户使用电子邮件地址和密码进行 Firebase 身份验证,还可以管理应用中基于密码的帐号。
准备工作
- 将 Firebase 添加至您的 JavaScript 项目。
- 如果您尚未将应用关联至您的 Firebase 项目,请在 Firebase 控制台进行关联。
- 启用“电子邮件地址/密码”登录机制:
- 在 Firebase 控制台中,打开 Auth 部分。
- 在 Sign-in method(登录方法)标签页中,启用电子邮件地址/密码登录方法,然后点击保存。
创建基于密码的帐号
如需创建使用密码的新用户帐号,请在您的应用的登录页面中完成以下步骤:
- 当新用户使用您的应用注册表单进行注册时,完成您的应用需要的所有新帐号验证步骤,例如验证新帐号的密码是否正确输入并且符合您规定的密码复杂度要求。
- 将新用户的电子邮件地址和密码传递给
createUserWithEmailAndPassword
方法,创建一个新帐号:Web version 9
import { getAuth, createUserWithEmailAndPassword } from "firebase/auth"; const auth = getAuth(); createUserWithEmailAndPassword(auth, email, password) .then((userCredential) => { // Signed in const user = userCredential.user; // ... }) .catch((error) => { const errorCode = error.code; const errorMessage = error.message; // .. });
Web version 8
firebase.auth().createUserWithEmailAndPassword(email, password) .then((userCredential) => { // Signed in var user = userCredential.user; // ... }) .catch((error) => { var errorCode = error.code; var errorMessage = error.message; // .. });
您还可以在此处捕捉并处理错误。如需获取错误代码列表,请参阅身份验证参考文档。
让用户使用电子邮件地址和密码登录
让用户使用密码登录的步骤与创建新帐号的步骤类似。在您的应用的登录页面中,执行以下操作:
- 当用户登录您的应用时,将该用户的电子邮件地址和密码传递给
signInWithEmailAndPassword
:Web version 9
import { getAuth, signInWithEmailAndPassword } from "firebase/auth"; const auth = getAuth(); signInWithEmailAndPassword(auth, email, password) .then((userCredential) => { // Signed in const user = userCredential.user; // ... }) .catch((error) => { const errorCode = error.code; const errorMessage = error.message; });
Web version 8
firebase.auth().signInWithEmailAndPassword(email, password) .then((userCredential) => { // Signed in var user = userCredential.user; // ... }) .catch((error) => { var errorCode = error.code; var errorMessage = error.message; });
您还可以在此处捕捉并处理错误。如需获取错误代码列表,请参阅身份验证参考文档。
后续步骤
在用户首次登录后,系统会创建一个新的用户帐号,并将其与该用户登录时使用的凭据(即用户名和密码、手机号码或者身份验证提供方信息)相关联。此新帐号存储在您的 Firebase 项目中,无论用户采用何种方式登录,您项目中的每个应用都可以使用此帐号来识别用户。
-
在您的应用中,建议通过在
Auth
对象上设置观测者 (observer) 来了解用户的身份验证状态。然后,您便可从User
对象获取用户的基本个人资料信息。请参阅管理用户。 在您的 Firebase Realtime Database 和 Cloud Storage 安全规则中,您可以从
auth
变量获取已登录用户的唯一用户 ID,然后利用此 ID 来控制用户可以访问哪些数据。
您可以将身份验证服务提供方凭据关联至现有用户帐号,让用户可以使用多个身份验证服务提供方登录您的应用。
如需让用户退出登录,请调用 signOut
:
Web version 9
import { getAuth, signOut } from "firebase/auth"; const auth = getAuth(); signOut(auth).then(() => { // Sign-out successful. }).catch((error) => { // An error happened. });
Web version 8
firebase.auth().signOut().then(() => { // Sign-out successful. }).catch((error) => { // An error happened. });