Firebase Auth, в пользовательских токенах каким должен быть какой-то uid?

https://firebase.google.com/docs/auth/admin/create-custom-токены

const uid = 'some-uid';

getAuth()
  .createCustomToken(uid)
  .then((customToken) => {
    // Send token back to client
  })
  .catch((error) => {
    console.log('Error creating custom token:', error);
  });

Я не знаю, что вставить в «some-uid» в этом сценарии. Может быть, мне следует ввести уникальный идентификатор, который никогда не использовался. Я планирую использовать другие социальные сети, которые Firebase не предоставляет.


кстати, если он будет реализован таким образом, будет ли он хорошо вписываться в список аутентификации консоли Firebase, как успешный вход в Google? с уид?

Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
1
0
22
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

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

I plan to do other social sign in & up that firebase does not provide.

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

UID Firebase не предоставляется, и у меня нет другого выбора, кроме как получить уникальное значение от третьего лица и использовать его для входа с помощью пользовательского токена? Так что это единственный способ.. Хм, это было бы не так чисто.. Только этот пользовательский документ должен иметь дополнительное значение поля <first-party-uid>, и <provider> также должен хранить его в отдельном значении поля . И функция не может быть вызвана, даже если FirebaseUser.currentUser.uid? У вас не может быть uid, предоставленного Firebase. (Пользовательский токен в основном не является правом UID)

gaesae 10.04.2022 02:39

@gaesae, например, вы вводите информацию о пользователях в Firestore или около того? Возможно, вы можете использовать идентификатор документа, поскольку он будет уникальным для этого пользователя. Нет, токен не является UID

Dharmaraj 10.04.2022 05:52

Я только что реализовал вход с помощью пользовательских токенов... и затем я понял, что uid выходит как uid, который я записал. Он не создается случайным образом, как при использовании gmail. это наверное невозможно да?

gaesae 10.04.2022 07:54

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

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

UID Firebase не предоставляется, и у меня нет другого выбора, кроме как получить уникальное значение от третьего лица и использовать его для входа с помощью пользовательского токена? Так что это единственный способ.. Хм, это было бы не так чисто.. Только этот пользовательский документ должен иметь дополнительное значение поля <first-party-uid>, и <provider> также должен хранить его в отдельном значении поля . И функция не может быть вызвана, даже если FirebaseUser.currentUser.uid? У вас не может быть uid, предоставленного Firebase. (Пользовательский токен в основном не является правом UID)

gaesae 10.04.2022 02:39

Я только что реализовал вход с помощью пользовательских токенов... и затем я понял, что uid выходит как uid, который я записал. Он не создается случайным образом, как при использовании gmail. это наверное невозможно да?

gaesae 10.04.2022 07:54

Другие вопросы по теме