Możesz użyć uwierzytelniania Firebase, aby umożliwić użytkownikom logowanie się do Twojej aplikacji przy użyciu jednej lub kilku metod logowania, w tym logowania za pomocą adresu e-mail i hasła, oraz dostawców tożsamości federacyjnych, takich jak Google Sign-in i Facebook Login. Z tego samouczka dowiesz się, jak zacząć korzystać z uwierzytelniania Firebase, pokazując, jak dodać adres e-mail i hasło logowania do aplikacji.
Połącz swoją aplikację z Firebase
- Zainstaluj pakiet SDK Firebase .
- W konsoli Firebase dodaj aplikację do projektu Firebase.
Dodaj uwierzytelnianie Firebase do swojej aplikacji
Dodaj zależność dla uwierzytelniania
Podfile
doPodfile
projektu:pod 'Firebase/Auth'
Uruchom
pod install
i otwórz utworzony plik.xcworkspace
.
(Opcjonalnie) Twórz prototypy i testuj za pomocą pakietu Firebase Local Emulator Suite
Zanim porozmawiamy o tym, jak Twoja aplikacja uwierzytelnia użytkowników, przedstawmy zestaw narzędzi, których możesz użyć do prototypowania i testowania funkcji uwierzytelniania: Firebase Local Emulator Suite. Jeśli decydujesz się na techniki uwierzytelniania i dostawców, wypróbowywanie różnych modeli danych z danymi publicznymi i prywatnymi przy użyciu reguł bezpieczeństwa uwierzytelniania i Firebase lub prototypowanie projektów interfejsu użytkownika logowania, możliwość pracy lokalnie bez wdrażania usług na żywo może być świetnym pomysłem .
Emulator uwierzytelniania jest częścią pakietu lokalnego emulatora, który umożliwia aplikacji interakcję z emulowaną zawartością i konfiguracją bazy danych, a także opcjonalnie z emulowanymi zasobami projektu (funkcje, inne bazy danych i reguły zabezpieczeń). Należy pamiętać, że pakiet Local Emulator Suite nie obsługuje jeszcze emulowanego magazynu w chmurze.
Korzystanie z emulatora uwierzytelniania obejmuje tylko kilka kroków:
- Dodanie wiersza kodu do konfiguracji testowej aplikacji w celu nawiązania połączenia z emulatorem.
-
firebase emulators:start
z katalogu głównego lokalnego projektufirebase emulators:start
. - Używanie interfejsu użytkownika pakietu lokalnego emulatora do interaktywnego prototypowania lub interfejsu API REST emulatora uwierzytelniania do testowania nieinteraktywnego.
Szczegółowy przewodnik jest dostępny pod adresem Połącz swoją aplikację z emulatorem uwierzytelniania . Aby uzyskać więcej informacji, zobacz wprowadzenie do pakietu lokalnego emulatora .
Przejdźmy teraz do uwierzytelniania użytkowników.
Zainicjuj pakiet SDK Firebase
W delegowaniu aplikacji najpierw zaimportuj pakiet SDK Firebase:
Szybki
import Firebase
Cel C
@import Firebase;
Następnie w application:didFinishLaunchingWithOptions:
metoda zainicjuj obiekt FirebaseApp
:
Szybki
// Use Firebase library to configure APIs
FirebaseApp.configure()
Cel C
// Use Firebase library to configure APIs
[FIRApp configure];
Nasłuchuj stanu uwierzytelnienia
Dla każdego widoku aplikacji, który wymaga informacji o zalogowanym użytkowniku, dołącz detektor do obiektu FIRAuth
. Ten odbiornik jest wywoływany za każdym razem, gdy zmienia się stan logowania użytkownika.
Dołącz detektor do metody viewWillAppear
kontrolera viewWillAppear
:
Szybki
handle = Auth.auth().addStateDidChangeListener { (auth, user) in
// ...
}
Cel C
self.handle = [[FIRAuth auth]
addAuthStateDidChangeListener:^(FIRAuth *_Nonnull auth, FIRUser *_Nullable user) {
// ...
}];
I odłącz detektor w metodzie viewWillDisappear
kontrolera viewWillDisappear
:
Szybki
Auth.auth().removeStateDidChangeListener(handle!)
Cel C
[[FIRAuth auth] removeAuthStateDidChangeListener:_handle];
Zarejestruj nowych użytkowników
Utwórz formularz, który pozwoli nowym użytkownikom zarejestrować się w Twojej aplikacji przy użyciu adresu e-mail i hasła. Gdy użytkownik wypełni formularz, potwierdź adres e-mail i hasło podane przez użytkownika, a następnie przekaż je do metody createUser
:
Szybki
Auth.auth().createUser(withEmail: email, password: password) { authResult, error in
// ...
}
Cel C
[[FIRAuth auth] createUserWithEmail:email
password:password
completion:^(FIRAuthDataResult * _Nullable authResult,
NSError * _Nullable error) {
// ...
}];
Zaloguj istniejących użytkowników
Utwórz formularz, który umożliwi istniejącym użytkownikom logowanie się przy użyciu ich adresu e-mail i hasła. Gdy użytkownik wypełni formularz, wywołaj metodę signIn
:
Szybki
Auth.auth().signIn(withEmail: email, password: password) { [weak self] authResult, error in
guard let strongSelf = self else { return }
// ...
}
Cel C
[[FIRAuth auth] signInWithEmail:self->_emailField.text
password:self->_passwordField.text
completion:^(FIRAuthDataResult * _Nullable authResult,
NSError * _Nullable error) {
// ...
}];
Uzyskaj informacje o użytkowniku
Po pomyślnym zalogowaniu się użytkownika możesz uzyskać informacje o użytkowniku. Na przykład w odbiorniku stanu uwierzytelniania :
Szybki
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 += " "
}
// ...
}
Cel 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;
// ...
}
Następne kroki
Dowiedz się, jak dodać obsługę innych dostawców tożsamości i anonimowych kont gości: