0

这个问题已经在这里问过了,但是由于 AngularFire 更新了他们的 API,提供的解决方案不再可用。

我正在做的是使用电子邮件/密码创建新用户帐户,将该用户存储在 Firebase 身份验证服务中,并将额外信息存储在数据库中。

但是,在身份验证中,用户的密钥为simplelogin:29,而在数据中,每个用户的哈希密钥为-JpwB9oUVkeT_XRdiX2V。我确实需要他们的钥匙是一样的。

下面是创建新用户的代码,使用 auth.$createUser 注册并在用户模型中存储额外信息。

var ref = new Firebase('https://myapp.firebaseio.com/');
var auth = $firebaseAuth(ref);

auth.$createUser({
    email: user.email,
    password: user.password 
    }).then(function(regUser) {

    var ref = new Firebase('https://myapp.firebaseio.com/users/')
    var firebaseUser = $firebaseArray(ref);

    var userInfo = {
        key         : regUser.uid, // ex: simplelogin:29
        date        : Firebase.ServerValue.TIMESTAMP,
        firstname   : user.firstname,
        lastname    : user.lastname,
        email       : user.email,
    }; // user info

    firebaseUser.$add(userInfo);
});

它可以工作,但不是应该的方式,因为用户在身份验证和数据中的密钥仍然不同。

4

2 回答 2

2

当您存储用户数据时,您通常希望键入uid. 毕竟uid已经是唯一的并且使用 is 作为关键确保您永远不会有两个相同的节点uid

当您调用$add它时,它会为您正在存储的对象生成一个新的所谓推送 ID。当您有数据列表时这很好,但在这种情况下,您的数据结构更像是映射:您映射uid到用户信息。

所以解决方案是不调用$add,而是:

var ref = new Firebase('https://myapp.firebaseio.com/');
var auth = $firebaseAuth(ref);

auth.$createUser({
    email: user.email,
    password: user.password 
}).then(function(regUser) {

    var ref = new Firebase('https://myapp.firebaseio.com/users/')

    var userInfo = {
        key         : regUser.uid, // ex: simplelogin:29
        date        : Firebase.ServerValue.TIMESTAMP,
        firstname   : user.firstname,
        lastname    : user.lastname,
        email       : user.email,
    }; // user info

    ref.child(regUser.uid).set(userInfo);
});

请注意,这只是使用常规的Firebase JavaScript SDK,它将与您可能已经拥有的数据上的任何 AngularFire 侦听器完全交互。

于 2015-05-22T18:13:36.253 回答
0

你也可以尝试这样的事情:

var empsRef = ref.child("http://sample.com/employees");

empsRef.child('11111').set({
  lastname: "Lee",
  firstname: "Kang"
});

empsRef.child('22222').set({
  lastname: "Nut",
  firstname: "Dough"
});

输出应如下所示:

"employees" : {
  "11111" : {
    "lastname" : "Lee",
    "firstname": "Kang"
  },
  "22222" : {
    "lastname" : "Nut",
    "firstname": "Dough"
  }
}

于 2016-04-21T03:29:05.167 回答