关于Stack I上类似问题的信息,结果如下:
数据库:
{
"user" : {
"xbStJyCtfzf472" : {
"avatar" : "avatar",
"email" : "email@gmail.com",
"fbId" : 10154200898,
"lastLogin" : "Tue Mar 14 22:31:36 GMT+01:00 2017",
"registerDate" : "Tue Mar 14 22:31:36 GMT+01:00 2017",
"uid" : "xbStJyCwY5Ttfzf472",
"username" : "myName"
}
},
"usernames" : {
"myName" : "xbStJyCtfzf472"
}
}
规则:
{
"rules": {
".read": "auth != null",
".write": "auth != null",
"users": {
"$uid": {
".write": "auth !== null && auth.uid === $uid",
".read": "auth !== null && auth.provider === 'password'",
"username": {
".validate": "
!root.child('usernames').child(newData.val()).exists() ||
root.child('usernames').child(newData.val()).val() == $uid"
}
}
}
}
}
Android Java代码:
public void addUserToDatabase(final long fbId){
final FirebaseUser user = FirebaseAuth.getInstance().getCurrentUser();
if (user != null) {
final String username = "myName";
//add the user
mDatabase.child("usernames").child(username).runTransaction(new Transaction.Handler() {
@Override
public Transaction.Result doTransaction(MutableData mutableData) {
if (mutableData.getValue() == null) {
mutableData.setValue(user.getUid());
return Transaction.success(mutableData);
}
return Transaction.abort();
}
@Override
public void onComplete(DatabaseError firebaseError, boolean commited, DataSnapshot dataSnapshot) {
if (commited) {
String email = user.getEmail();
String uid = user.getUid();
String avatar = "avatar1";
long mFbId = fbId;
String registered = Calendar.getInstance().getTime().toString();
String lastLogin = Calendar.getInstance().getTime().toString();
Log.w("AUTH", "username saved");
mDatabase.child("user").child(uid).setValue(new User(username, email, uid, avatar, mFbId, lastLogin, registered));
} else {
Log.w("AUTH", "username exists");
}
}
});
}
}
这样可行,因为如果我尝试使用相同的userName注册帐户,则不会在我的数据库中创建任何内容。 然而,在我的身份验证/用户中创建了一个用户。我可以看到这会导致各种各样的问题。
我应该如何在检查完成之前以不注册用户的方式强制数据库中的唯一用户名?
编辑:为了澄清,我可以检测到用户名被取走,并提示用户输入另一个用户名。 但是,如果用户在执行此操作时接到电话/退出我的应用,那么他们的电子邮件将被验证(即他们无法再次注册),但他们不会拥有用户对象在我的数据库中,所以他们永远无法使用我的应用程序。
答案 0 :(得分:7)
简答:
首先注册用户,然后提示他们输入用户名,当他们这样做时,在数据库中创建他们的用户对象。
解决问题的方法:
如果用户出于某些原因在决定用户名时退出应用程序,导致他们的电子邮件存储在身份验证表中,而数据库中没有User
- 对象,那么我们就遇到了问题。
要解决这个问题,每当用户登录时,我们都可以检查他们的UID是否存在于User
- 表中,如果有,那就太棒了!如果没有,那么我们再次提示他们输入用户名,然后创建用户对象。