توفّر حِزم تطوير البرامج (SDK) الخاصة بخدمة Firebase Authentication طريقة بسيطة لرصد الأخطاء المختلفة التي قد تحدث عند استخدام طرق المصادقة. تعرض حِزم تطوير البرامج (SDK) الخاصة بـ Flutter هذه الأخطاء من خلال فئة FirebaseAuthException.
يتم توفير code وmessage كحد أدنى، ولكن في بعض الحالات، يتم توفير سمات إضافية مثل عنوان البريد الإلكتروني وبيانات الاعتماد. على سبيل المثال، إذا كان المستخدم يحاول تسجيل الدخول باستخدام عنوان بريد إلكتروني وكلمة مرور،
يمكن رصد أي أخطاء يتم عرضها بشكل صريح:
try {
await FirebaseAuth.instance.signInWithEmailAndPassword(
email: "barry.allen@example.com",
password: "SuperSecretPassword!"
);
} on FirebaseAuthException catch (e) {
print('Failed with error code: ${e.code}');
print(e.message);
}
توفّر كل طريقة رموز خطأ ورسائل مختلفة استنادًا إلى نوع طلب المصادقة. تقدّم Reference API تفاصيل حديثة حول الأخطاء لكل طريقة.
قد تظهر أخطاء أخرى مثل too-many-requests أو operation-not-allowed إذا بلغت حصة Firebase Authentication،
أو إذا لم تفعّل مقدّم خدمة مصادقة معيّنًا.
التعامل مع أخطاء account-exists-with-different-credential
إذا فعّلت الإعداد "حساب واحد لكل عنوان بريد إلكتروني" في وحدة تحكّم Firebase،
عندما يحاول مستخدم تسجيل الدخول إلى موفّر خدمة (مثل Google) باستخدام عنوان بريد إلكتروني متوفّر لموفّر خدمة آخر لمستخدم Firebase
(مثل Facebook)، سيتم عرض الخطأ auth/account-exists-with-different-credential مع الفئة AuthCredential (الرمز المميز لمعرّف Google).
لإكمال عملية تسجيل الدخول إلى مقدّم الخدمة المقصود، على المستخدم أولاً تسجيل الدخول إلى مقدّم الخدمة الحالي (مثل Facebook)، ثم الربط بمقدّم الخدمة السابق
AuthCredential (الرمز المميّز لمعرّف Google).
FirebaseAuth auth = FirebaseAuth.instance;
// Create a credential from a Google Sign-in Request
var googleAuthCredential = GoogleAuthProvider.credential(accessToken: 'xxxx');
try {
// Attempt to sign in the user in with Google
await auth.signInWithCredential(googleAuthCredential);
} on FirebaseAuthException catch (e) {
if (e.code == 'account-exists-with-different-credential') {
// The account already exists with a different credential
String email = e.email;
AuthCredential pendingCredential = e.credential;
// Fetch a list of what sign-in methods exist for the conflicting user
List<String> userSignInMethods = await auth.fetchSignInMethodsForEmail(email);
// If the user has several sign-in methods,
// the first method in the list will be the "recommended" method to use.
if (userSignInMethods.first == 'password') {
// Prompt the user to enter their password
String password = '...';
// Sign the user in to their account with the password
UserCredential userCredential = await auth.signInWithEmailAndPassword(
email: email,
password: password,
);
// Link the pending credential with the existing account
await userCredential.user.linkWithCredential(pendingCredential);
// Success! Go back to your application flow
return goToApplication();
}
// Since other providers are now external, you must now sign the user in with another
// auth provider, such as Facebook.
if (userSignInMethods.first == 'facebook.com') {
// Create a new Facebook credential
String accessToken = await triggerFacebookAuthentication();
var facebookAuthCredential = FacebookAuthProvider.credential(accessToken);
// Sign the user in with the credential
UserCredential userCredential = await auth.signInWithCredential(facebookAuthCredential);
// Link the pending credential with the existing account
await userCredential.user.linkWithCredential(pendingCredential);
// Success! Go back to your application flow
return goToApplication();
}
// Handle other OAuth providers...
}
}