如何为aposauce创建拦截器?

时间:2019-05-09 11:43:28

标签: reactjs react-router

我将apisauce用于我的React应用程序的HTTP工作,也使用React-router和Redux Saga。

我有一个问题,我们是否可以在apisauce中创建一个拦截器,并且可以将我们的应用程序重定向到/ login路由?

我添加了监视器,这是apisauce的功能,但是我不知道如何将我的应用重定向到/ login路由。

感谢您的帮助。

我的显示器示例:

constructor() {
  this.api = apisauce.create({
    baseURL: env.API_URL,
    headers: {
      Authorization: `Bearer ${localStorage.getItem('user') || ''}`,
    },
    timeout: 15000,
  });

  this.api.addMonitor(this.tokenMonitor);
}

private tokenMonitor(response: any) {
  const { ok, status } = response;

  if (!ok && status !== 200) {
    // I should do redirect here
    localStorage.removeItem('user');
  }
}

1 个答案:

答案 0 :(得分:2)

也许您可以使用,像这样:

@Component
public class AccBeanFactoryPostProcessor implements BeanFactoryPostProcessor, EnvironmentAware {

    private Environment environment;

    @Override
    public void setEnvironment(Environment environment) {
        this.environment = environment;
    }

    @SuppressWarnings("unchecked")
    @Override
    public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
        List<String> packages = environment.getProperty("prong.nfcloan.jackson.json-sub-types-package", List.class);
        // do something
    }
}

我希望这会有所帮助。