reactjs - 从 React Native 中的 api 拦截器(组件外部)重定向到屏幕

标签 reactjs native react-native

我正在开发一个 React Native 应用程序,该应用程序使用 JWT token 对请求进行身份验证。为此,我创建了 axios 请求和响应拦截器,将 token 添加到每个请求(请求拦截器),并在响应具有 401 HTTP 状态(响应拦截器)时将用户重定向到登录屏幕。

问题是我还没有找到在组件外部进行重定向的方法。下面的代码位于 API 服务中,每当我想要进行 API 调用时都会导入该代码。

由于此服务是无状态的并且不关心从哪个组件调用它,我需要做什么才能重定向到我的登录屏幕?

// Response interceptor
axiosInstance.interceptors.response.use(
  response => {
    // Do something with response data
    if (response.status === 401) {
      deviceStorage.removeData('token');
      // TODO:
      // Redirect to login page
    }
    return response;
  },
  error => {
    // Do something with response error
    return Promise.reject(error);
  }
);

最佳答案

关注官方文档:Navigating without the navigation prop

尝试这样的事情

// App.js

import { createStackNavigator, createAppContainer } from 'react-navigation';
import NavigationService from './NavigationService';

const TopLevelNavigator = createStackNavigator({ /* ... */ })

const AppContainer = createAppContainer(TopLevelNavigator);

export default class App extends React.Component {
  // ...

  render() {
    return (
      <AppContainer
        ref={navigatorRef => {
          NavigationService.setTopLevelNavigator(navigatorRef);
        }}
      />
    );
  }
}

// NavigationService.js

import { NavigationActions } from 'react-navigation';

let _navigator;

function setTopLevelNavigator(navigatorRef) {
  _navigator = navigatorRef;
}

function navigate(routeName, params) {
  _navigator.dispatch(
    NavigationActions.navigate({
      routeName,
      params,
    })
  );
}

// add other navigation functions that you need and export them

export default {
  navigate,
  setTopLevelNavigator,
};

关于reactjs - 从 React Native 中的 api 拦截器(组件外部)重定向到屏幕,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54232213/

相关文章:

javascript - 我的文件(pdf、xlsx、docx ..)在 Reactjs 中下载损坏或有错误

android - HTTP/2 来了。原生 Android 应用程序如何利用它?

javascript - 使用 react-native-router-flux 与 nativebase

react-native - React Native - 创建和导出/下载 PDF 文件

javascript - React-Router v4 - 将参数传递给 withRouter

javascript - 如何在 react 中显示图像数组中的图像

javascript - API:使构造函数在 JavaScript 中无需括号即可链接

java - 为什么 Java 的 InflaterInputStream(和其他类似类)只在其内部 Inflater 上有条件地调用结束

javascript - 从 URL 加载图像时正在加载旋转器

reactjs - 在 useEffect 中使用 redux 操作的最佳方法是什么?