为什么' axios.get'返回一个promise对象?

时间:2017-06-09 11:25:28

标签: node.js express axios

我一直在尝试使用Axios来检查用户是否是经过身份验证的服务器端(Node + Express + Passport)。

如果用户通过身份验证,则服务器会发回"已连接"字符串,否则,它会发回"未连接"字符串。

Router.get('/isAuth', function (req, res, next) {
    if (req.isAuthenticated()) {
        return res.status(200).send('Connected');
    } else {
        return res.status(200).send('Not connected');
    }
});

我写了一个简单的函数来检查服务器的响应:

function isAuth() {
  return axios.get('http://localhost:3000/endpoints/isAuth')
  .then((response) => {
    if (response.data === "Connected") {
      return true;
    } else {
      return false;
    }
  })
  .catch((error) => {
    console.log(error)
  })
}

如果用户已连接,则该函数应返回true,反之亦然。

现在,当我尝试在控制台中记录函数的结果时,这就是我得到的:

Promise {[[PromiseStatus]]: "pending", [[PromiseValue]]: undefined}
  __proto__ : Promise
  [[PromiseStatus]] : "resolved"
  [[PromiseValue]] : false

如您所见,返回的值是一个promise对象,而所需的输出最好是" True"或"错误"。

1 个答案:

答案 0 :(得分:5)

isAuth会执行异步请求,这需要一些时间。因此它不能直接返回true或false。它将返回一个获取该布尔值的promise。要访问您的布尔值,您必须将isAuth()函数视为promise:

isAuth().then(isAuthenticated => console.log(isAuthenticated));

<强>更新

此代码:

var test = isAuth();

将同步返回承诺,不会等待响应结果

如果您想访问承诺的响应,则需要使用:

test.then(value => ...);

如果你真的想要同步的http请求(阻止你的应用,直到请求得到解决),你可以结帐https://github.com/ForbesLindesay/sync-request

但如果它不仅仅用于测试目的,你实际上不想使用。

您可以考虑的另一件事是使用节点7.6附带的async/await,但您首先应该完全理解承诺的概念