我将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');
}
}
答案 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
}
}
我希望这会有所帮助。