Bạn có thể sử dụng Firebase Authentication để cho phép người dùng đăng nhập vào ứng dụng của mình bằng một hoặc phương thức đăng nhập khác, bao gồm đăng nhập bằng địa chỉ email và mật khẩu, và nhà cung cấp danh tính được liên kết, chẳng hạn như Đăng nhập bằng Google và Đăng nhập Facebook. Chiến dịch này hướng dẫn sẽ giúp bạn bắt đầu với Firebase Authentication bằng cách chỉ cho bạn cách thêm địa chỉ email và mật khẩu để đăng nhập vào ứng dụng của bạn.
Kết nối ứng dụng của bạn với Firebase
- Cài đặt Firebase SDK.
- Trong bảng điều khiển Firebase, hãy thêm ứng dụng vào dự án Firebase của bạn.
Thêm Firebase Authentication vào ứng dụng
Sử dụng Trình quản lý gói Swift để cài đặt và quản lý các phần phụ thuộc Firebase.
- Trong Xcode, khi dự án ứng dụng của bạn đang mở, hãy chuyển đến Tệp > Thêm gói.
- Khi được nhắc, hãy thêm kho lưu trữ SDK nền tảng Apple của Firebase:
- Chọn thư viện Firebase Authentication.
- Thêm cờ
-ObjC
vào mục Cờ trình liên kết khác trong chế độ cài đặt bản dựng của mục tiêu. - Khi hoàn tất, Xcode sẽ tự động bắt đầu phân giải và tải xuống các phần phụ thuộc trong nền.
https://github.com/firebase/firebase-ios-sdk.git
(Không bắt buộc) Tạo nguyên mẫu và thử nghiệm bằng Firebase Local Emulator Suite
Trước khi nói về cách ứng dụng của bạn xác thực người dùng, hãy giới thiệu một số bạn có thể dùng để tạo nguyên mẫu và kiểm thử chức năng của Authentication: Firebase Local Emulator Suite. Nếu bạn đang quyết định chọn các kỹ thuật xác thực và nhà cung cấp, thử các mô hình dữ liệu khác nhau với dữ liệu công khai và riêng tư bằng cách sử dụng Authentication và Firebase Security Rules hoặc tạo nguyên mẫu cho thiết kế giao diện người dùng đăng nhập, có thể làm việc cục bộ mà không triển khai dịch vụ trực tiếp có thể là ý tưởng hay.
Trình mô phỏng Authentication là một phần của Local Emulator Suite, cho phép ứng dụng của bạn tương tác với cấu hình và nội dung cơ sở dữ liệu được mô phỏng, như cũng như các tài nguyên dự án được mô phỏng (không bắt buộc) (các hàm, cơ sở dữ liệu khác, và quy tắc bảo mật).
Việc sử dụng trình mô phỏng Authentication chỉ bao gồm vài bước:
- Thêm một dòng mã vào cấu hình kiểm thử của ứng dụng để kết nối với trình mô phỏng.
- Trên gốc của thư mục dự án cục bộ, chạy
firebase emulators:start
. - Sử dụng giao diện người dùng Local Emulator Suite để tạo nguyên mẫu tương tác, hoặc API REST của trình mô phỏng Authentication để kiểm thử không tương tác.
Bạn có thể xem hướng dẫn chi tiết tại bài viết Kết nối ứng dụng với trình mô phỏng Authentication. Để biết thêm thông tin, hãy xem phần giới thiệu về Local Emulator Suite.
Giờ hãy tiếp tục với cách xác thực người dùng.
Chạy SDK Firebase
Trong đại biểu ứng dụng, trước tiên hãy nhập SDK Firebase:
Swift
import FirebaseCore
Objective-C
@import FirebaseCore;
Sau đó, trong phương thức application:didFinishLaunchingWithOptions:
, hãy khởi chạy
Đối tượng FirebaseApp
:
Swift
// Use Firebase library to configure APIs
FirebaseApp.configure()
Objective-C
// Use Firebase library to configure APIs
[FIRApp configure];
Theo dõi trạng thái xác thực
Đối với mỗi chế độ xem của ứng dụng cần thông tin về người dùng đã đăng nhập,
đính kèm trình nghe vào đối tượng FIRAuth
. Trình nghe này sẽ được gọi bất cứ khi nào
trạng thái đăng nhập của người dùng sẽ thay đổi.
Đính kèm trình nghe vào phương thức viewWillAppear
của trình điều khiển khung hiển thị:
Swift
handle = Auth.auth().addStateDidChangeListener { auth, user in
// ...
}
Objective-C
self.handle = [[FIRAuth auth]
addAuthStateDidChangeListener:^(FIRAuth *_Nonnull auth, FIRUser *_Nullable user) {
// ...
}];
Đồng thời, hãy tách trình nghe trong phương thức viewWillDisappear
của trình điều khiển khung hiển thị:
Swift
Auth.auth().removeStateDidChangeListener(handle!)
Objective-C
[[FIRAuth auth] removeAuthStateDidChangeListener:_handle];
Đăng ký người dùng mới
Tạo một biểu mẫu cho phép người dùng mới đăng ký ứng dụng của bạn bằng địa chỉ email của họ
địa chỉ và mật khẩu. Khi người dùng hoàn tất biểu mẫu, hãy xác thực email
địa chỉ và mật khẩu do người dùng cung cấp, sau đó chuyển các thông tin này đến createUser
phương thức:
Swift
Auth.auth().createUser(withEmail: email, password: password) { authResult, error in
// ...
}
Objective-C
[[FIRAuth auth] createUserWithEmail:email
password:password
completion:^(FIRAuthDataResult * _Nullable authResult,
NSError * _Nullable error) {
// ...
}];
Đăng nhập người dùng hiện có
Tạo biểu mẫu cho phép người dùng hiện tại đăng nhập bằng địa chỉ email của họ
và mật khẩu. Khi người dùng hoàn tất biểu mẫu, hãy gọi phương thức signIn
:
Swift
Auth.auth().signIn(withEmail: email, password: password) { [weak self] authResult, error in
guard let strongSelf = self else { return }
// ...
}
Objective-C
[[FIRAuth auth] signInWithEmail:self->_emailField.text
password:self->_passwordField.text
completion:^(FIRAuthDataResult * _Nullable authResult,
NSError * _Nullable error) {
// ...
}];
Lấy thông tin người dùng
Sau khi người dùng đăng nhập thành công, bạn có thể nhận thông tin về người dùng đó. Cho ví dụ: trong trình nghe trạng thái xác thực:
Swift
if let user = user {
// The user's ID, unique to the Firebase project.
// Do NOT use this value to authenticate with your backend server,
// if you have one. Use getTokenWithCompletion:completion: instead.
let uid = user.uid
let email = user.email
let photoURL = user.photoURL
var multiFactorString = "MultiFactor: "
for info in user.multiFactor.enrolledFactors {
multiFactorString += info.displayName ?? "[DispayName]"
multiFactorString += " "
}
// ...
}
Objective-C
if (user) {
// The user's ID, unique to the Firebase project.
// Do NOT use this value to authenticate with your backend server,
// if you have one. Use getTokenWithCompletion:completion: instead.
NSString *email = user.email;
NSString *uid = user.uid;
NSMutableString *multiFactorString = [NSMutableString stringWithFormat:@"MultiFactor: "];
for (FIRMultiFactorInfo *info in user.multiFactor.enrolledFactors) {
[multiFactorString appendString:info.displayName];
[multiFactorString appendString:@" "];
}
NSURL *photoURL = user.photoURL;
// ...
}
Các bước tiếp theo
Tìm hiểu cách thêm tính năng hỗ trợ cho các nhà cung cấp danh tính và khách ẩn danh khác tài khoản: