php axios session为空,终于解决了如何 使用axios设置session过期的跳转

通常如果我们想要使用axios设置过期时的跳转,我们的思路是 拦截axios返回的response进行操作。如下官方文档

bVbtw6f?w=801&h=537

下面便是我再项目中的用法:

bVbtw73?w=607&h=350

其中store和router是引入的vue-router和vuex的实例,用于在非.vue的文件中操作store和router。

然而,在过期后,不仅弹出了过期的提示,还弹出了组件中axios.post调用失败后catch中的提示。

bVbtxbS?w=730&h=325

这不是我要的,我就要简简单单弹出个过期就完了,不需要其他乱七八糟的提示。

这是什么原因呢,因为上面interceptors.response中的 MessageBox.alert弹框之后,执行了return操作,把response结果返回给了组件中的axios.post。 所以接下来的解决方案就是,我弹框后,不return了

bVbtxeJ?w=602&h=354

唉,事与愿违。还是不行。和上面一样的结果,都弹出了两个框。

看来直接return result不行,那么return一个promise呢,promise中resolved(result)呢?

bVbtxhb?w=828&h=445

bVbtxhq?w=672&h=298

漂亮,和预期一样( 长舒一口气)

点击确定,跳转到登录页面。

bVbtxhJ?w=593&h=407

等等,什么鬼,为什么又跳出一次? 看来是因为组件中,不仅调用一次axios.post, 而是发了好几个请求。所以每进 一次instance.interceptors.response,都会判断一下。

那我们让他弹一次不就行了。

bVbtxrl?w=645&h=579

设置个定时器,这个定时器只进入一次,后面都不会进入。

点击超时的弹框后,直接跳转到登录页面,再也没有出现超时弹框,好,完美。

bVbtxr2?w=622&h=460

至此问题解决。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值