4

我是新手,所以请耐心等待。我正在尝试使用带有电子邮件和密码的 fire base 简单登录。我有这个工作:

var authClient = new FirebaseAuthClient(fireRef, function(error, user) {
          if (error) {
            // an error occurred while attempting login

                if(error.code === "INVALID_EMAIL"){ 
                    $('#log_email_error').hide();
                    $('#log_pass_error').hide();
                    $('#log_email_error').html("Invalid email specified.").fadeIn();
                    $('.login_button').removeClass('login_button_success').attr('value','Log in');          
                }
                if (error.code === "INVALID_PASSWORD") {
                    $('#log_email_error').hide();
                    $('#log_pass_error').hide();
                    $('#log_pass_error').html("The specified password is incorrect..").fadeIn();
                    $('.login_button').removeClass('login_button_success').attr('value','Log in');
                }


            console.log(error);
          } else if (user) {
            // user authenticated with Firebase
            hideLogin();
            $('.userInfo_cont').show();
            $('.userInfo').html('<div> '+  user.email + ' <span class="grey">| </span> </div>');
            $('.logout').on('click',function(){
                authClient.logout();
            });

            console.log('User ID: ' + user.id + ', Provider: ' + user.provider);

          } else {
            // user is logged out
            $('.userInfo_cont').hide();
            showLogin();
          }
    });

但是,当用户注册时,我想在 firebase/users 区域中存储一些额外的信息,我可以在注册时这样做:

$('#submit_reg').on('click',function(){
            var firstName = $('#regFirstname').val();
            var lastName = $('#regLastname').val();
            var email = $('#regUsername').val();
            var password = $('#regPassword').val();

            authClient.createUser(email, password, function(error, user) {
              if (!error) {
                   console.log('User Id: ' + user.id + ', Email: ' + user.email);

                       authClient.login('password', {
                                          email: email,
                                          password: password,
                                          rememberMe: false
                                        });


                       hideLogin();


                        userInfo = {

                            userId : user.id,
                            firstName : firstName,
                            lastName : lastName,
                            email : user.email

                        }

                        var url = USERS_LOCATION + "/" + user.id;
                        var userRef = new Firebase(url);

                        console.log(userInfo);

                        userRef.set(userInfo);



                  }else{
                    //display error

                    alert(error);

                  }
            });



        });

我的问题是当我实现文档中的读写规则时:

{
  "rules": {
    "users":{
     "$userid": {
        ".read": "auth.id == $userid",
        ".write": "auth.id == $userid"
      }
    }
  }
}

当用户注册时,我得到一个权限被拒绝。因此它可以很好地注册用户,但不会将附加数据写入 /users/id 区域。

任何帮助将非常感激。

克雷格

4

1 回答 1

5

在上面的代码段中,您正在调用login(),然后立即调用set()。这是有问题的,因为该login()方法是异步的,并且您几乎总是可以保证set()在登录尝试方法返回之前调用了该方法,因为login()它是非阻塞的,但会对 Firebase 服务器进行网络调用。

这意味着即使您使用login()正确的电子邮件和密码进行呼叫,您仍会尝试在身份验证过程完成之前设置数据。

我建议将您的set()逻辑移动到一个块中,该块仅在您确定用户已经通过身份验证时才会执行,例如在您调用new FirebaseAuthClient()并检测到登录用户时传递的回调中。

于 2013-03-12T23:46:07.350 回答