为了账号安全,请及时绑定邮箱和手机立即绑定

react 中使用 axios , 如何获取登录接口返回的 token ?

react 中使用 axios , 如何获取登录接口返回的 token ?

交互式爱情 2019-05-13 08:56:35
是这样的!项目使用react+axios,axios发送请求需要在header中设置token。问题是,token是从登录api接口返回的。那么很明显,这个token值得存储成全局变量。因为其他组件中也要用axios发送接口需要用到这个token。存到localstorage里,每次发送请求都从localstorage中读取。用redux存储想问3个问题:用方式1会不会有性能问题,localstorage毕竟不同于普通的函数方式2的话,如果项目本身用不到redux,似乎有点大材小用额~,怪怪的。是不是又别的方式,大家是怎么处理的呢。
查看完整描述

2 回答

?
四季花海

TA贡献1811条经验 获得超5个赞

一般来说你需要localstorage和window(global)配合使用;首先你从后台获取了token,可以把token赋给window也就是this,这样你在任何地方都可以使用this.token,但是用户一旦关闭浏览器,这个js执行环境消失,第二次再打开浏览器浏览的时候,就需要重新去登录获取token,很显然这并不是我们想要的保存登录信息,那么正确的步骤是:1,登录成功后,this.token=res.data.token,同时将token存储在localstorage,这样每次请求都用this.token,而不需要去localstorage取2.当用户关闭了浏览器,下次进入的时候才取localstorage,然后把取到的结果赋给this,也就是this.token=你取到的token3.只要当用户退出登录的时候才removelocalstorage里面的token
                            
查看完整回答
反对 回复 2019-05-13
  • 2 回答
  • 0 关注
  • 2414 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信