关于Vue项目中,登录请求使用Vuex处理返回的token值

本文介绍了一种将用户登录后获得的Token既保存在Vuex中以便于应用内使用,又通过本地存储LocalStorage实现持久化的存储方案。该方案解决了Token在页面刷新后的丢失问题,并保持了Vuex状态的纯净。

描述:但我们在做一个用户登录功能时,向服务器发送完登录请求,成功后;服务器会返回我们一个token值来保存到本地储存中.一般我们都会将返回的token值保存到本地存储 localstorage中

Token 是用户登录成功之后服务端返回的一个身份令牌,在项目中的多个业务中需要使用到:

  • 访问需要授权的 API 接口
  • 校验页面的访问权限

但是我们只有在第一次用户登录成功之后才能拿到 Token。

所以为了能在其它模块中获取到 Token 数据,我们需要把它存储到一个公共的位置,方便随时取用。

往哪儿存?

  • 本地存储
    • 获取麻烦
    • 数据不是响应式
  • Vuex 容器(推荐)
    • 获取方便
    • 响应式的

在这里插入图片描述

1.那么将token值保存在vuex中
1.)首先,导入相关文件,生成vuex结构
2.)在state中声明保存token的变量
3.)在mutation中,对变量进行赋值(将服务器返回的token值赋值给声明的变量)
在这里插入图片描述
2.在写登录功能的代码中,导入vuex文件,在请求成功下面调用vuex中的方法
在这里插入图片描述
**此时在浏览器控制台的vuex插件中可以看到已经将token值保存在vuex中
在这里插入图片描述
**这里有一个小问题:虽然将token保存在vuex中,在浏览器中也可以看到;但是页面一刷新,vuex中保存的token值就会消失,变成空的,就是因为没有做到持久化保存

那么要解决这个问题,我们既要存在vuex中,也要存在本地储存localstorage中,但是为了保证vuex文件的纯净,代码不显得臃肿,我们将本地储存的代码再次封装到一个js文件中.

这里导出了两个方法,分别是把存储token和读取token在这里插入图片描述
然后回到vuex文件中
在这里插入图片描述
综上:不仅将服务器返回的token值保存到vuex中,实现数据的响应式也方便了数据的随时取用,同时也持久化的储存了token值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值