Xác thực qua điện thoại cho phép người dùng đăng nhập vào Firebase bằng điện thoại của họ làm trình xác thực. Một tin nhắn SMS được gửi tới người dùng (sử dụng số điện thoại được cung cấp) có chứa một mã duy nhất. Khi mã đã được ủy quyền, người dùng có thể đăng nhập vào Firebase.
Số điện thoại mà người dùng cuối cung cấp để xác thực sẽ được Google gửi và lưu trữ để cải thiện khả năng ngăn chặn spam và lạm dụng trên toàn bộ dịch vụ của Google, bao gồm nhưng không giới hạn ở Firebase. Các nhà phát triển phải đảm bảo rằng họ có sự đồng ý thích hợp của người dùng cuối trước khi sử dụng dịch vụ đăng nhập số điện thoại Xác thực Firebase.authentication
Xác thực điện thoại Firebase không được hỗ trợ ở tất cả các quốc gia. Vui lòng xem Câu hỏi thường gặp của họ để biết thêm thông tin.
Cài đặt
Trước khi bắt đầu với Xác thực điện thoại, hãy đảm bảo bạn đã làm theo các bước sau:
- Bật Điện thoại làm phương thức Đăng nhập trong bảng điều khiển Firebase .
- Android : Nếu bạn chưa đặt hàm băm SHA-1 cho ứng dụng của mình trong bảng điều khiển Firebase , hãy làm như vậy. Xem Xác thực ứng dụng khách của bạn để biết thông tin về cách tìm hàm băm SHA-1 của ứng dụng của bạn.
- iOS : Trong Xcode, bật thông báo đẩy cho dự án của bạn và đảm bảo rằng khóa xác thực APN của bạn được định cấu hình với Firebase Cloud Messaging (FCM) . Ngoài ra, bạn phải bật chế độ nền cho thông báo từ xa. Để xem giải thích chi tiết về bước này, hãy xem tài liệu Xác thực điện thoại iOS của Firebase .
- Web : Đảm bảo rằng bạn đã thêm miền ứng dụng của mình trên bảng điều khiển Firebase , trong miền chuyển hướng OAuth .
lưu ý ; Đăng nhập bằng số điện thoại chỉ khả dụng trên thiết bị thực và trên web. Để kiểm tra quy trình xác thực của bạn trên trình giả lập thiết bị, vui lòng xem Kiểm tra .
Cách sử dụng
SDK xác thực Firebase cho Flutter cung cấp hai cách riêng lẻ để đăng nhập người dùng bằng số điện thoại của họ. Các nền tảng gốc (ví dụ: Android & iOS) cung cấp chức năng xác thực số điện thoại khác với web, do đó, có hai phương pháp dành riêng cho từng nền tảng:
- Nền tảng gốc :
verifyPhoneNumber
. - Nền tảng web :
signInWithPhoneNumber
.
Gốc: verifyPhoneNumber
Trên nền tảng gốc, số điện thoại của người dùng trước tiên phải được xác minh và sau đó người dùng có thể đăng nhập hoặc liên kết tài khoản của họ với PhoneAuthCredential
.
Trước tiên, bạn phải nhắc người dùng về số điện thoại của họ. Sau khi được cung cấp, hãy gọi phương thức verifyPhoneNumber()
:
await FirebaseAuth.instance.verifyPhoneNumber(
phoneNumber: '+44 7123 123 456',
verificationCompleted: (PhoneAuthCredential credential) {},
verificationFailed: (FirebaseAuthException e) {},
codeSent: (String verificationId, int? resendToken) {},
codeAutoRetrievalTimeout: (String verificationId) {},
);
Có 4 cuộc gọi lại riêng biệt mà bạn phải xử lý, mỗi cuộc gọi sẽ xác định cách bạn cập nhật giao diện người dùng ứng dụng:
- verifyCompleted : Tự động xử lý mã SMS trên thiết bị Android.
- verifyFailed : Xử lý các sự kiện lỗi như số điện thoại không hợp lệ hoặc hạn ngạch SMS đã bị vượt quá hay chưa.
- codeSent : Xử lý khi một mã đã được gửi đến thiết bị từ Firebase, dùng để nhắc người dùng nhập mã.
- codeAutoRetrievalTimeout : Xử lý thời gian chờ khi xử lý mã SMS tự động không thành công.
xác minh đã hoàn thành
Trình xử lý này sẽ chỉ được gọi trên các thiết bị Android hỗ trợ giải mã SMS tự động.
Khi mã SMS được gửi tới thiết bị, Android sẽ tự động xác minh mã SMS mà không yêu cầu người dùng nhập mã theo cách thủ công. Nếu sự kiện này xảy ra, PhoneAuthCredential
sẽ tự động được cung cấp, có thể được sử dụng để đăng nhập hoặc liên kết số điện thoại của người dùng.
FirebaseAuth auth = FirebaseAuth.instance;
await auth.verifyPhoneNumber(
phoneNumber: '+44 7123 123 456',
verificationCompleted: (PhoneAuthCredential credential) async {
// ANDROID ONLY!
// Sign the user in (or link) with the auto-generated credential
await auth.signInWithCredential(credential);
},
);
xác minh không hoàn thành
Nếu Firebase trả về lỗi, chẳng hạn như số điện thoại không chính xác hoặc nếu hạn ngạch SMS cho dự án đã vượt quá, FirebaseAuthException
sẽ được gửi tới trình xử lý này. Trong trường hợp này, bạn sẽ nhắc người dùng của mình đã xảy ra sự cố tùy thuộc vào mã lỗi.
FirebaseAuth auth = FirebaseAuth.instance;
await auth.verifyPhoneNumber(
phoneNumber: '+44 7123 123 456',
verificationFailed: (FirebaseAuthException e) {
if (e.code == 'invalid-phone-number') {
print('The provided phone number is not valid.');
}
// Handle other errors
},
);
mãĐã gửi
Khi Firebase gửi mã SMS đến thiết bị, trình xử lý này được kích hoạt bằng một verificationId
và resendToken
(A resendToken
chỉ được hỗ trợ trên thiết bị Android, thiết bị iOS sẽ luôn trả về giá trị null
).
Sau khi được kích hoạt, đây sẽ là thời điểm tốt để cập nhật giao diện người dùng ứng dụng của bạn để nhắc người dùng nhập mã SMS mà họ mong đợi. Khi mã SMS đã được nhập, bạn có thể kết hợp ID xác minh với mã SMS để tạo PhoneAuthCredential
mới :
FirebaseAuth auth = FirebaseAuth.instance;
await auth.verifyPhoneNumber(
phoneNumber: '+44 7123 123 456',
codeSent: (String verificationId, int? resendToken) async {
// Update the UI - wait for the user to enter the SMS code
String smsCode = 'xxxx';
// Create a PhoneAuthCredential with the code
PhoneAuthCredential credential = PhoneAuthProvider.credential(verificationId: verificationId, smsCode: smsCode);
// Sign the user in (or link) with the credential
await auth.signInWithCredential(credential);
},
);
Theo mặc định, Firebase sẽ không gửi lại tin nhắn SMS mới nếu nó được gửi gần đây. Tuy nhiên, bạn có thể ghi đè hành vi này bằng cách gọi lại phương thức verifyPhoneNumber
bằng mã thông báo gửi lại cho đối số forceResendingToken
. Nếu thành công, tin nhắn SMS sẽ được gửi lại.
codeAutoRetrievalTimeout
Trên các thiết bị Android hỗ trợ giải mã SMS tự động, trình xử lý này sẽ được gọi nếu thiết bị không tự động giải quyết một tin nhắn SMS trong một khung thời gian nhất định. Khi khung thời gian đã trôi qua, thiết bị sẽ không cố gắng giải quyết bất kỳ tin nhắn đến nào nữa.
Theo mặc định, thiết bị đợi trong 30 giây, tuy nhiên, điều này có thể được tùy chỉnh với đối số timeout
:
FirebaseAuth auth = FirebaseAuth.instance;
await auth.verifyPhoneNumber(
phoneNumber: '+44 7123 123 456',
timeout: const Duration(seconds: 60),
codeAutoRetrievalTimeout: (String verificationId) {
// Auto-resolution timed out...
},
);
Web: signInWithPhoneNumber
Trên nền tảng web, người dùng có thể đăng nhập bằng cách xác nhận rằng họ có quyền truy cập vào điện thoại bằng cách nhập mã SMS được gửi đến số điện thoại được cung cấp. Để tăng cường bảo mật và ngăn chặn thư rác, người dùng được yêu cầu chứng minh họ là con người bằng cách hoàn thành tiện ích Google reCAPTCHA . Sau khi xác nhận, mã SMS sẽ được gửi.
SDK xác thực Firebase cho Flutter sẽ quản lý tiện ích reCAPTCHA ngay lập tức theo mặc định, tuy nhiên, cung cấp quyền kiểm soát cách tiện ích này được hiển thị và định cấu hình nếu cần. Để bắt đầu, hãy gọi phương thức signInWithPhoneNumber
bằng số điện thoại.
FirebaseAuth auth = FirebaseAuth.instance;
// Wait for the user to complete the reCAPTCHA & for an SMS code to be sent.
ConfirmationResult confirmationResult = await auth.signInWithPhoneNumber('+44 7123 123 456');
Việc gọi phương thức trước tiên sẽ kích hoạt tiện ích reCAPTCHA hiển thị. Người dùng phải hoàn thành bài kiểm tra trước khi mã SMS được gửi. Sau khi hoàn tất, bạn có thể đăng nhập người dùng bằng cách cung cấp mã SMS cho phương thức confirm
trên phản ConfirmationResult
kết quả đã giải quyết:
UserCredential userCredential = await confirmationResult.confirm('123456');
Giống như các luồng đăng nhập khác, một lần đăng nhập thành công sẽ kích hoạt mọi trình lắng nghe trạng thái xác thực mà bạn đã đăng ký trong suốt ứng dụng của mình.
Cấu hình reCAPTCHA
Tiện ích reCAPTCHA là một luồng được quản lý hoàn toàn nhằm cung cấp bảo mật cho ứng dụng web của bạn.
Đối số thứ hai của signInWithPhoneNumber
chấp nhận một phiên bản RecaptchaVerifier
tùy chọn có thể được sử dụng để quản lý tiện ích con. Theo mặc định, tiện ích sẽ hiển thị dưới dạng tiện ích ẩn khi quy trình đăng nhập được kích hoạt. Tiện ích "ẩn" sẽ xuất hiện dưới dạng chế độ toàn trang ở đầu ứng dụng của bạn.
Tuy nhiên, có thể hiển thị một tiện ích nội tuyến mà người dùng phải nhấn rõ ràng để tự xác minh.
Để thêm tiện ích nội tuyến, hãy chỉ định ID phần tử DOM cho đối số container
của phiên bản RecaptchaVerifier
. Phần tử phải tồn tại và trống nếu không sẽ xảy ra lỗi. Nếu không có đối số container
nào được cung cấp, thì tiện ích sẽ được hiển thị là "ẩn".
ConfirmationResult confirmationResult = await auth.signInWithPhoneNumber('+44 7123 123 456', RecaptchaVerifier(
container: 'recaptcha',
size: RecaptchaVerifierSize.compact,
theme: RecaptchaVerifierTheme.dark,
));
Bạn có thể tùy ý thay đổi kích thước và chủ đề bằng cách tùy chỉnh các đối số về size
và theme
như hình trên.
Cũng có thể lắng nghe các sự kiện, chẳng hạn như liệu reCAPTCHA đã được người dùng hoàn thành hay chưa, reCAPTCHA đã hết hạn hay đã xảy ra lỗi:
RecaptchaVerifier(
onSuccess: () => print('reCAPTCHA Completed!'),
onError: (FirebaseAuthException error) => print(error),
onExpired: () => print('reCAPTCHA Expired!'),
);
thử nghiệm
Firebase cung cấp hỗ trợ cho các số điện thoại thử nghiệm cục bộ:
- Trên Bảng điều khiển Firebase, chọn nhà cung cấp xác thực "Số điện thoại" và nhấp vào danh sách thả xuống "Số điện thoại để kiểm tra".
- Nhập số điện thoại mới (ví dụ
+44 7444 555666
) và mã kiểm tra (ví dụ123456
).
Nếu cung cấp số điện thoại thử nghiệm cho các phương thức verifyPhoneNumber
hoặc signInWithPhoneNumber
, thì sẽ không có SMS nào thực sự được gửi. Thay vào đó, bạn có thể cung cấp mã kiểm tra trực tiếp cho PhoneAuthProvider
hoặc với trình xử lý kết quả xác nhận của signInWithPhoneNumber
.