首页 > 解决方案 > Firebase ID 令牌在一小时内到期

问题描述

所以我redux-saga在我的 react-native 应用程序中使用并尝试使用刷新令牌但没有用,所以我的方法是在 app.js 中使用以下方法,以便专门为每个请求获取令牌并强制刷新它:

  handleResponse = async () => {
    const {dispatch} = this.store;
    await axios.interceptors.request.use(config => {
      // Important: request interceptors **must** return the request.
      console.log("refreshToken")
      let user =  firebase.auth().currentUser;
        firebase.auth().onAuthStateChanged(function(user) {   if (user) {
          console.log("auth changed: ",user)
          user.getIdToken(true).then((token) => {
                setAccessToken(token);
                config.headers.authorization = token;
              }
          );
        } else { console.log("didn't auth change") } });
      console.log("req in handle response: ",JSON.stringify(config));
      return config;
    });
    axios.interceptors.response.use(config => config, (err) => {
      if (err.response) {
        const response = err.response;
        const state = this.store.getState();
        if (
            response.status === 401
            && state.auth.isAuthenticated
        ) {
          dispatch(logout());
        }
      }
      return Promise.reject(err);
    });
  };

但它总是在一个小时后结束,向我抛出以下错误::

Firebase ID 令牌已过期。从您的客户端应用程序获取新令牌并重试(auth/id-token-expired)。有关如何检索 ID 令牌的详细信息,请参阅https://firebase.google.com/docs/auth/admin/verify-id-tokens 。

所以我想知道是否有另一种方法可以尝试从我这边解决问题?

提前致谢。

标签: javascriptreact-nativefirebase-authenticationredux-sagaauth-token

解决方案


Firebase 身份验证令牌每小时自动刷新一次。这是 SDK 的一项功能,您无需执行任何操作即可启用它。

您绝对不想firebase.auth().onAuthStateChanged为每个请求打电话。这会启动一个持久监听器,并在每次使用时添加一个新回调。通常,您只为您的应用程序全局添加一个侦听器,并在发生更新时使用其更新。

如果您需要知道 SDK 何时刷新令牌以便立即获取新令牌,则应改为使用onIdTokenChanged设置回调,该回调将在每次用户令牌更改时调用。同样,您应该只为您的应用程序全局设置其中之一,并在请求时使用其当前值。


推荐阅读