6
var user = null;    

this.showLoginDialogGoogle  = function(){

        var ref = new Firebase("https://googlelogin1.firebaseio.com");
        ref.authWithOAuthPopup("google", function(error, authData) {
            if (error) {
                console.log("Login Failed!", error);
            } else {
                console.log("Authenticated successfully with payload:", authData);
                user = authData;
                This.goToPage('/profile');
                $rootScope.flag=true;
                $rootScope.$digest();
            }
        });
    };

我已经使用 firebase google 身份验证对用户进行了身份验证。问题是当我刷新页面时,我的会话过期并authData变为null. 我该怎么做才能在刷新页面后authData保留身份验证时获得的数据?

4

1 回答 1

1

您需要监控身份验证状态

// Register the callback to be fired every time auth state changes
var ref = new Firebase("https://<YOUR-FIREBASE-APP>.firebaseio.com");
ref.onAuth(function authDataCallback(authData) {
  if (authData) {
    console.log("User " + authData.uid + " is logged in with " + authData.provider);
  } else {
    console.log("User is logged out");
  }
});

请注意,您没有使用 AngularFire 身份验证包装器。虽然您的方法将对用户进行身份验证,但您必须自己通知 Angular 更新的范围(请参阅 参考资料$timeout())。如果您不想自己这样做,请查看 AngularFire 的身份验证包装器,特别是$onAuth()

于 2015-08-11T22:11:41.403 回答