Tạo người dùng
Bạn tạo người dùng mới trong dự án Firebase theo 4 cách:
- Gọi phương thức
createUserWithEmailAndPassword()
. - Đăng nhập vào người dùng lần đầu tiên thông qua nhà cung cấp danh tính được liên kết, chẳng hạn như Đăng nhập bằng Google, Đăng nhập Facebook hoặc Apple.
Bạn cũng có thể tạo người dùng đã được xác thực mật khẩu mới từ phần Xác thực của Bảng điều khiển của Firebase, trên trang Người dùng.
Lấy hồ sơ của người dùng
Để lấy thông tin hồ sơ của người dùng, hãy sử dụng các thuộc tính của User
. Có
3 cách để lấy đối tượng User
đại diện cho người dùng hiện tại:
Luồng
authStateChanges
,idTokenChanges
vàuserChanges
: trình nghe sẽ nhận đượcUser
hiện tại hoặcnull
nếu không có người dùng nào đã xác thực:FirebaseAuth.instance .authStateChanges() .listen((User? user) { if (user != null) { print(user.uid); } });
Khi ứng dụng khởi động, một sự kiện sẽ kích hoạt sau thông tin đăng nhập của người dùng (nếu có) từ bộ nhớ cục bộ đã được khôi phục, tức là người nghe sẽ luôn có được được gọi khi trạng thái người dùng được khởi tạo. Sau đó, bất cứ khi nào xác thực trạng thái thay đổi, thì một sự kiện mới sẽ được gửi đi cùng với trạng thái người dùng được cập nhật.
Bằng cách theo dõi trạng thái xác thực, bạn có thể xây dựng giao diện người dùng sẽ phản ứng với những thay đổi này trong trạng thái xác thực.
Đối tượng
UserCredential
được xác thực (signIn
-) trả về phương thức: đối tượngUserCredential
có thuộc tínhuser
với thuộc tính hiện tạiUser
:final userCredential = await FirebaseAuth.instance.signInWithCredential(credential); final user = userCredential.user; print(user?.uid);
Thuộc tính
currentUser
của thực thểFirebaseAuth
: nếu bạn chắc chắn Người dùng hiện đang đăng nhập, bạn có thể truy cậpUser
từcurrentUser
thuộc tính:if (FirebaseAuth.instance.currentUser != null) { print(FirebaseAuth.instance.currentUser?.uid); }
currentUser
có thể có trạng tháinull
vì 2 lý do:- Người dùng chưa đăng nhập.
- Khởi tạo xong đối tượng xác thực. Nếu bạn dùng một trình nghe để giữ lại theo dõi trạng thái đăng nhập của người dùng, bạn không cần xử lý trường hợp này.
Lấy thông tin hồ sơ theo nhà cung cấp cụ thể của người dùng
Để nhận thông tin hồ sơ được truy xuất từ các nhà cung cấp dịch vụ đăng nhập được liên kết với
hãy sử dụng thuộc tính providerData
. Ví dụ:
if (user != null) {
for (final providerProfile in user.providerData) {
// ID of the provider (google.com, apple.com, etc.)
final provider = providerProfile.providerId;
// UID specific to the provider
final uid = providerProfile.uid;
// Name, email address, and profile photo URL
final name = providerProfile.displayName;
final emailAddress = providerProfile.email;
final profilePhoto = providerProfile.photoURL;
}
}
Cập nhật hồ sơ của người dùng
Bạn có thể cập nhật thông tin hồ sơ cơ bản của người dùng—tên hiển thị của người dùng
và URL ảnh hồ sơ (bằng các phương thức update
). Ví dụ:
await user?.updateDisplayName("Jane Q. User");
await user?.updatePhotoURL("https://example.com/jane-q-user/profile.jpg");
Đặt địa chỉ email của người dùng
Bạn có thể thiết lập địa chỉ email của người dùng bằng phương thức updateEmail()
. Ví dụ:
await user?.updateEmail("janeq@example.com");
Gửi email xác minh cho người dùng
Bạn có thể gửi email xác minh địa chỉ đến người dùng có
sendEmailVerification()
. Ví dụ:
await user?.sendEmailVerification();
Bạn có thể tuỳ chỉnh mẫu email được sử dụng trong phần Xác thực của bảng điều khiển của Firebase, trên trang Mẫu email. Xem Mẫu email trong Trung tâm trợ giúp Firebase.
Bạn cũng có thể chuyển trạng thái thông qua tiếp tục URL để chuyển hướng trở lại vào ứng dụng khi gửi email xác minh.
Ngoài ra, bạn có thể bản địa hoá email xác minh bằng cách cập nhật ngôn ngữ trên thực thể Xác thực trước khi gửi email. Ví dụ:
await FirebaseAuth.instance.setLanguageCode("fr");
await user?.sendEmailVerification();
Đặt mật khẩu của người dùng
Bạn có thể đặt mật khẩu của người dùng bằng phương thức updatePassword()
. Ví dụ:
await user?.updatePassword(newPassword);
Gửi email đặt lại mật khẩu
Bạn có thể gửi email đặt lại mật khẩu cho người dùng có sendPasswordResetEmail()
. Ví dụ:
await FirebaseAuth.instance
.sendPasswordResetEmail(email: "user@example.com");
Bạn có thể tuỳ chỉnh mẫu email được sử dụng trong phần Xác thực của bảng điều khiển của Firebase, trên trang Mẫu email. Xem Mẫu email trong Trung tâm trợ giúp Firebase.
Bạn cũng có thể chuyển trạng thái thông qua tiếp tục URL để chuyển hướng trở lại cho ứng dụng khi gửi email đặt lại mật khẩu.
Ngoài ra, bạn có thể bản địa hoá email đặt lại mật khẩu bằng cách cập nhật ngôn ngữ trên thực thể Xác thực trước khi gửi email. Ví dụ:
await FirebaseAuth.instance.setLanguageCode("fr");
Bạn cũng có thể gửi email đặt lại mật khẩu từ bảng điều khiển của Firebase.
Xóa người dùng
Bạn có thể xoá tài khoản người dùng bằng phương thức delete()
. Ví dụ:
await user?.delete();
Bạn cũng có thể xoá người dùng khỏi phần Xác thực của Bảng điều khiển của Firebase, trên trang Người dùng.
Xác thực lại người dùng
Một số hành động nhạy cảm về bảo mật, chẳng hạn như
xoá tài khoản,
đặt địa chỉ email chính, và
thay đổi mật khẩu – yêu cầu người dùng phải
đăng nhập gần đây. Nếu bạn thực hiện một trong những hành động này và người dùng đó đăng nhập
cách đây quá lâu, hành động này không thành công và gửi ra một FirebaseAuthException
kèm theo mã
requires-recent-login
.
Khi điều này xảy ra, hãy xác thực lại người dùng bằng cách nhận thông tin đăng nhập mới
từ người dùng rồi truyền thông tin đăng nhập đến reauthenticate
. Ví dụ:
// Prompt the user to re-provide their sign-in credentials.
// Then, use the credentials to reauthenticate:
await user?.reauthenticateWithCredential(credential);
Nhập tài khoản người dùng
Bạn có thể nhập tài khoản người dùng từ một tệp vào dự án Firebase bằng cách sử dụng
Lệnh auth:import
của Firebase CLI. Ví dụ:
firebase auth:import users.json --hash-algo=scrypt --rounds=8 --mem-cost=14