开发者问题收集

Axios 拦截器运行多次

2022-02-24
2204

我有这个拦截器,如果用户未经授权,它会注销用户。但是,我得到的响应不止一个,因此拦截器的运行次数与我得到的响应次数一样多(4)。有没有办法让它只在第一次运行?

这是我的代码:

api.interceptors.response.use(
(response) => response,
(err) => {
  if (err.response.status === 401 && isLoggedIn) {
    api
      .delete("auth/sign_out")
      .then((resp) => {
        clearLocalStorage();
      })
      .catch((err) => {
        clearLocalStorage();
      });
  } else {
    return Promise.reject(err);
  }
  return err;
}

);

1个回答

您可能需要类似这样的操作来“锁定”可能的可重入调用:

let isLoggingOut = false; // global

// ...

api.interceptors.response.use(
  (response) => response,
  async (err) => {
    if (err.response.status === 401 && isLoggedIn) {
      if(!isLoggingOut) {
        isLoggingOut = true;  // disallow re-entrant calls
        try {
          await api.delete('auth/sign_out');
        } catch (deletionError) {
          // throw errors away
        } finally {
          clearLocalStorage();
          isLoggingOut = false;
          isLoggedIn = false; // if the variable is assignable
        }
      }
    }
    return err;
  },
);
AKX
2022-02-24