Firebase Authentication SDK'ları,
kimlik doğrulama yöntemlerinden birini seçin. Flutter'ın SDK'ları, bu hataları FirebaseAuthException
üzerinden gösterir.
sınıfını kullanır.
En azından bir code
ve message
sağlanır ancak bazı durumlarda e-posta adresi gibi ek özellikler
Yeterlilik Belgesi ve Yeterlilik Belgesi de verilir. Örneğin, kullanıcı bir e-posta adresi ve şifreyle oturum açmaya çalışıyorsa
bildirilen tüm hatalar açık bir şekilde yakalanabilir:
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);
}
Her yöntem, kimlik doğrulama çağrısı türüne bağlı olarak çeşitli hata kodları ve mesajları sağlar. İlgili içeriği oluşturmak için kullanılan Referans API, her yöntemdeki hatalar hakkında güncel ayrıntılar sağlar.
Firebase Authentication kotasına ulaşırsanız too-many-requests
veya operation-not-allowed
gibi diğer hatalar bildirilebilir.
veya belirli bir kimlik doğrulama sağlayıcıyı etkinleştirmemiş olabilirsiniz.
account-exists-with-different-credential
Hatayı Giderme
Firebase konsolunda E-posta adresi başına bir hesap ayarını etkinleştirdiyseniz,
Kullanıcı, başka bir Firebase kullanıcısının sağlayıcısına ait bir e-postayla bir sağlayıcıda (ör. Google) oturum açmaya çalıştığında
(ör. Facebook), auth/account-exists-with-different-credential
hatası, bir AuthCredential
sınıfı (Google kimlik jetonu) ile birlikte gönderilir.
Oturum açma akışını istenen sağlayıcıya göndermek için kullanıcının önce mevcut sağlayıcıda (ör. Facebook) oturum açması ve ardından eski sağlayıcıya bağlanması gerekir
AuthCredential
(Google kimliği jetonu).
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...
}
}