ajax401错误,如何在React-Router中从ajax调用中获取401错误时重定向到登录页面?

我会尝试这样的事情:

>使用组件的上下文来操作路由器(this.context.router.transitionTo()).

>将此方法作为参数传递给API标注.

// component.js,contextTypes: {

router: React.PropTypes.func

},componentDidMount: function() {

api.getOne(this.props.params.id,this.context.router,data) {

if (err) {

this.setErrorMessage('System Error!');

} else if (this.isMounted()) {

this.setState({

user: data

});

}

}.bind(this));

},// api.js

var endCallback = function(cb,router,res) {

if (err && err.status == 401) {

return router.transitionTo('login');

}

if (res) {

cb(err,res.body);

} else {

cb(err);

}

};

get: function(cb,router) {

request

.get(BASE_URL + resources)

.end(endCallback.bind(null,cb,router));

},

我知道你不希望在每个经过身份验证的组件上进行回调,但我认为没有任何特殊的反应路由器快捷方式可以在路由器之外进行转换.

我能想到的另一件事就是在错误上启动一个全新的路由器并手动将其发送到登录路由.但我认为这不一定有效,因为它不在初始渲染方法之内.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值