Аутентификация с помощью Firebase с использованием специальной системы аутентификации

Вы можете интегрировать аутентификацию Firebase с собственной системой аутентификации, изменив свой сервер аутентификации так, чтобы он создавал специальные подписанные токены при успешном входе пользователя в систему. Ваше приложение получает этот токен и использует его для аутентификации в Firebase.

Прежде чем вы начнете

  1. Если вы еще этого не сделали, выполните действия, описанные в руководстве по началу работы .
  2. Установите и настройте Firebase Admin SDK . Обязательно инициализируйте SDK , указав правильные учетные данные для вашего проекта Firebase.

Аутентификация с помощью Firebase

  1. Когда пользователи входят в ваше приложение, отправляйте свои учетные данные для входа (например, имя пользователя и пароль) на ваш сервер аутентификации. Ваш сервер проверяет учетные данные и, если они действительны, создает собственный токен Firebase и отправляет его обратно в ваше приложение.

  2. После того как вы получите пользовательский токен от вашего сервера аутентификации, передайте его в signInWithCustomToken() для входа пользователя:

    try {
        final userCredential =
            await FirebaseAuth.instance.signInWithCustomToken(token);
        print("Sign-in successful.");
    } on FirebaseAuthException catch (e) {
        switch (e.code) {
            case "invalid-custom-token":
                print("The supplied token is not a Firebase custom auth token.");
                break;
            case "custom-token-mismatch":
                print("The supplied token is for a different Firebase project.");
                break;
            default:
                print("Unknown error.");
        }
    }
    

Следующие шаги

После того как пользователь создает новую учетную запись, эта учетная запись сохраняется как часть вашего проекта Firebase и может использоваться для идентификации пользователя в каждом приложении вашего проекта, независимо от того, какой метод входа использовал пользователь.

В своих приложениях вы можете получить базовую информацию профиля пользователя из объекта User . См. Управление пользователями .

В правилах безопасности базы данных реального времени и облачного хранилища Firebase вы можете получить уникальный идентификатор пользователя, вошедшего в систему, из переменной auth и использовать его для управления тем, к каким данным пользователь может получить доступ.

Вы можете разрешить пользователям входить в ваше приложение с использованием нескольких поставщиков аутентификации, привязав учетные данные поставщика аутентификации к существующей учетной записи пользователя.

Чтобы выйти из системы, вызовите signOut() :

await FirebaseAuth.instance.signOut();