2

我在服务器端有两种方法,如下所示:

var Future = require("fibers/future");

Meteor.methods({
  foo: function () {
     this.unblock();
     var f = new Future();
     setTimeout(function () {
         f.return(42);
     }, 10000);
     return f.wait();
  },
  bar: function () {
     return 43;
  }
});

从客户端调用这些方法时(使用浏览器控制台),它们工作正常(foo等待 10 秒,然后bar立即工作):

Meteor.call("foo", function (err, data) {
   console.log(err || data);
   // After 10 seconds: 42
});

Meteor.call("bar", function (err, data) {
   console.log(err || data);
   // Very quick (*instantly*): 43
});

但是,当有会话并且我们调用Meteor.logout(fn)时,回调 ( fn) 将在foo完成后等待。

我不想要那个。我希望该logout方法能够正常工作bar(不等待完成foo,而是立即工作)。

我怎样才能做到这一点?有没有办法解除封锁 logout或类似的东西?登录操作以相同的方式(当前)工作:它等待直到foo发送响应。

4

2 回答 2

5

这是该logout方法的预期行为。它一直等到服务器上的所有内容都完成,然后注销用户。

假设您正在使用accounts包(它创建Accounts全局变量),您可以查看定义logout方法的源代码:

logout(callback) {
    var self = this;
    self.connection.apply('logout', [], {
      wait: true
    }, function (error, result) {
      if (error) {
        callback && callback(error);
      } else {
        self.makeClientLoggedOut();
        callback && callback();
      }
    });
}

如果您真的希望注销立即生效Accounts.logout,您可以通过关闭该wait选项来覆盖该功能:

// Override the method and turn off the `wait` field
Accounts.logout = function () {
    var self = this;
    self.connection.apply('logout', [], {
      wait: false
    }, function (error, result) {
      if (error) {
        callback && callback(error);
      } else {
        self.makeClientLoggedOut();
        callback && callback();
      }
    });
};

(注意wait:false上面代码中的)

这可能会使事情崩溃(尤其是在客户端),因为Meteor.user()null在注销之后,但这必须进行测试。我希望在服务器上(在服务器方法的上下文中)Meteor.user()即使在用户注销的同时也是正确的对象。

于 2016-01-20T14:53:36.167 回答
2

除非我误会了你,否则你只需要fn 打完Meteor.logout电话再打。困难在于这可能会在用户仍然登录时运行,这正是他们允许您传递回调的原因。

仅调用fn一次logout完成并且用户已注销: Meteor.logout(fn)

发出注销请求后立即调用fn(此时用户实际上还没有被注销)。 Meteor.logout() fn()

于 2016-01-20T08:47:06.987 回答