如何在 Firebase 中添加带有电子邮件和密码的用户名?

Posted

技术标签:

【中文标题】如何在 Firebase 中添加带有电子邮件和密码的用户名?【英文标题】:How to add username with email and password in Firebase? 【发布时间】:2017-09-16 11:13:35 【问题描述】:

我正在使用 Firebase,我正在尝试使用电子邮件和密码将用户名添加到数据库中。

有没有办法做到这一点,还是createUserWithEmailAndPassword() 功能仅适用于电子邮件和密码?

signUp.addEventListener("click", function(user)

    var username = usernameTxt.value;
    var email = emailTxt.value;
    var password = passwordTxt.value;

    firebase.auth().createUserWithEmailAndPassword(email, password).catch(function(error)
    


      // Handle Errors here.
      var errorCode = error.code;
      var errorMessage = error.message;

      if (errorCode == 'auth/email-already-in-use')
      
            alert('email-already-in-use.');
        
        else
        
            alert(errorMessage);
        
          console.log(error);

    );
);

我发现如何使用 createUserWithEmailAndPassword() 函数添加用户名的解决方案:

firebase.auth().onAuthStateChanged(function(user) 

  var username = usernameTxt.value;

  if (user) 
    firebaseDataBase.ref('users/' + user.uid).set(
        email: user.email,
        uid : user.uid,
        username: username
    );


    console.log("User is signed in.");
   else 
     console.log("No user is signed in.");

  
);

【问题讨论】:

Add Extra Details on Firebase User Table的可能重复 【参考方案1】:

您可以创建一个users 端点并在其中存储自定义用户数据。

function writeUserData(userId, name, email, imageUrl) 
  firebase.database().ref('users/' + userId).set(
    username: name,
    email: email,
    profile_picture : imageUrl,
    // Add more stuff here
  );

看看https://firebase.google.com/docs/database/web/read-and-write

【讨论】:

【参考方案2】:

你需要自己创建那个数据库users子节点;-)

createUserWithEmailAndPassword 函数在 Firebase 身份验证服务中创建一个新用户。结果,数据库本身根本没有改变。

要将此新用户也添加到数据库中,请尝试:

firebase.database().ref("users").child(user.uid).set(...)

【讨论】:

所以我需要在 firebase.auth().createUserWithEmailAndPassword(email, password).catch(function(error) 中添加您的代码,对吗? 是的!一旦承诺返回就去做。【参考方案3】:

这不能通过createUserWithEmailAndPassword() 完成,但是有一个 firebase 方法可以做到这一点。 您需要监听身份验证状态何时更改获取用户,然后更新个人资料信息。见下文

此代码将出现在 createUserWithEmailAndPassword() 之后

 firebase.auth().onAuthStateChanged(function(user) 

                if (user) 

                   // Updates the user attributes:

                  user.updateProfile( // <-- Update Method here

                    displayName: "NEW USER NAME",
                    photoURL: "https://example.com/jane-q-user/profile.jpg"

                  ).then(function() 

                    // Profile updated successfully!
                    //  "NEW USER NAME"

                    var displayName = user.displayName;
                    // "https://example.com/jane-q-user/profile.jpg"
                    var photoURL = user.photoURL;

                  , function(error) 
                    // An error happened.
                  );     

                
    );

如 firebase User Api 所述:https://firebase.google.com/docs/reference/js/firebase.User#updateProfile

希望对你有帮助

【讨论】:

有没有办法确保 displayName 在所有用户中都是唯一的?也许通过请求用户名并先查看是否有任何内容?

以上是关于如何在 Firebase 中添加带有电子邮件和密码的用户名?的主要内容,如果未能解决你的问题,请参考以下文章

firebase:如何链接电子邮件验证和密码

如何首先在Firebase中发送电子邮件验证,然后创建帐户?

如何使用 Firebase 9 电子邮件和密码创建用户并将该用户的其他数据保存在 firebase db 集合中?

使用 Flutter firebase 自定义用户名和密码登录

在 Android 应用中使用 Firebase (BaaS) 存储电子邮件和密码时如何包含用户名?

如何将电子邮件地址添加到 firebase kotlin? [复制]