位置: IT常识 - 正文

关于 Token 过期问题的两种解决方案(token过期处理)

编辑:rootadmin
关于 Token 过期问题的两种解决方案

推荐整理分享关于 Token 过期问题的两种解决方案(token过期处理),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:token过期或者无效,token过期问题,token过期或者无效,token已过期3910013,如果token过期了,交给谁处理,如果token过期了,交给谁处理,关于token过期跳转登陆后如何还原之前的状态,token过期有什么影响,内容如对您有帮助,希望把文章链接给更多的朋友!

 对于token过期,我们有两种方案:

方案一:当我们操作某个需要token作为请求头的接口时,返回的数据错误error.response.status === 401,说明我们的token已经过期了。

我们希望当响应返回的数据是401身份过期时,让当前浏览页面强行跳转到登入页面,让用户手动更新token。拿到最新的token值后再跳回之前浏览的页面。增强用户体验。

实现原理:

再阻拦响应器中配置:

// 阻拦响应器request.interceptors.response.use(function (response) { return response}, async function (error) { if (error.response && error.response.status === 401) { // token续签方式1: //清空当前vuex保存的token(我们这的vuex和本地已经建立了关系,相当于也清空了本地token) store.commit('upUser', '') console.log(router.currentRoute.fullPath)// 当前路由的完整路径(#后面的) //这里我们采用?path=的方式保存当前浏览页面的完整路径, // push()会产生历史记录 而replace不会有历史记录 router.push({ path: `/login?path=${router.currentRoute.fullPath}` }) } return Promise.reject(error)})

再登入组件中给登入功能函数添加:

关于 Token 过期问题的两种解决方案(token过期处理)

 this.$router.replace({           path: this.$route.query.path || '/'         })

// 1.点击登入 async onSubmit () { try { const { data: res } = await loginAPI(this.user) //登录成功 // 不严谨的返回上次浏览的页面 // this.$router.back() // 推荐方式: // 登录后, 判断有未遂地址(有未遂地址的情况是:token过期,在阻拦响应器中实现对未遂地址的保存), 登入成功后跳转到未遂地址, 否则去/路径(跳到首页--这种情况是:用户主动前往登入页面的登入,没有未遂地址,登入成功后直接前往首页) // replace不会产生路由历史记录 this.$router.replace({ path: this.$route.query.path || '/' }) // 存储获取过来的token this.$store.commit('upUser', res.data) } catch (err) { console.log(err) if (err.response.status === 400) { this.$toast.fail('手机号或验证码错误') } else { this.$toast.fail('登入失败,请稍后再试') // 可能由于网络问题导致的登入失败 } } },

方案二:实现用户无感知的刷新token值,我们希望当响应返回的数据是401身份过期时,响应阻拦器自动帮我们刷新token值,而不是让用户手动更新token。拿到最新的token值后再重新发起刚刚因token过期的请求。从而实现无感知

前提是有后台的配合:

登入后后台接口返回值要求:必须提供刷新token的令牌

并且后台提供了刷新token的接口: (请求头要求是refresh_token)

注意:1. 在请求响应器中做判断在非刷新token的时候,给请求头配置token,而刷新token的时候,我们自己手动添加请求头为refresh_token

2.refresh_token也有过期的时候,这时只能强行让用户自己重新登入了

// 刷新用户tokenexport const updataTokenAPI = function () { return request({ method: 'PUT', url: '/v1_0/authorizations', headers: { Authorization: `Bearer ${store.state.user.refresh_token}` } })}

实现原理: 

import request from '@/utils/request'import store from '@/store'// 请求响应器request.interceptors.request.use(function (config) { // config :本次请求的配置对象 // config 里面有一个属性:headers const { user } = store.state//请求头未配置信息的时候才会配置 if (user.token && config.headers.Authorizatio === undefined) { config.headers.Authorization = `Bearer ${user.token}` } // 这里必须将config返回出去,否则请求会停在这 里 return config}, function (error) { // 如果请求出错(还没发送出去,可能是代码写错了的问题),就会进入这里 return Promise.reject(error)})// 阻拦响应器request.interceptors.response.use(function (response) { return response}, async function (error) { if (error.response && error.response.status === 401) { // token续签方式2: refreshToken(用户无感知) // 将过期的token值清空 store.commit('updataToken', '') //请求刷新token接口 const { data: res } = await updataTokenAPI() //保存新的token值 store.commit('updataToken', res.data.token) // 再调用一次未完成的请求啊(用户无感知) // error.config 就是上一次axios请求的配置对象 // console.dir(error.config) // 把新的token赋予到下一次axios请求的请求头中 error.config.headers.Authorization = 'Bearer ' + res.data.token // return到await的地方,将未完成的请求再次发起, return axios(error.config) } else if (error.response.status === 500 && error.config.url === '/v1_0/authorizations') { // 因为500的情况有很多种,refresh_token失效也是其中一种情况,所有再加上error.config.url === '/v1_0/authorizations'条件,确保是refresh_token失效情况 // 清空所有的token和refresh_toekn,并且强制跳转登录页面 store.commit('upUser', {}) router.push({ path: '/login' }) Toast.fail('身份已过期') } return Promise.reject(error)})

 

本文链接地址:https://www.jiuchutong.com/zhishi/288080.html 转载请保留说明!

上一篇:Element-UI--<el-switch>的@change回调函数的参数用法

下一篇:Escarpment Trail in Porcupine Mountains Wilderness State Park, Michigan (© Pat & Chuck Blackley/Alamy)

  • 网易云怎么设置主页呢(网易云怎么设置闹钟铃声)

    网易云怎么设置主页呢(网易云怎么设置闹钟铃声)

  • 苹果禁迅雷的原因(ios迅雷被苹果下架了 知乎)

    苹果禁迅雷的原因(ios迅雷被苹果下架了 知乎)

  • 微信笔记图标能换吗(微信笔记图标能删除吗)

    微信笔记图标能换吗(微信笔记图标能删除吗)

  • 苹果钱包添加卡无效(苹果钱包添加卡片无法连接applepay)

    苹果钱包添加卡无效(苹果钱包添加卡片无法连接applepay)

  • 怎样发一张照片的抖音(怎样发一张照片显示地点不能让人看出是网络盗图)

    怎样发一张照片的抖音(怎样发一张照片显示地点不能让人看出是网络盗图)

  • 聊天记录迁移能看到删掉的信息吗(聊天记录迁移能看到对方的聊天记录吗)

    聊天记录迁移能看到删掉的信息吗(聊天记录迁移能看到对方的聊天记录吗)

  • 微信视频号内测资格有什么用(微信视频号内测申请)

    微信视频号内测资格有什么用(微信视频号内测申请)

  • 同一个无线安卓能用苹果不能(同一个无线安卓能上网,苹果不行)

    同一个无线安卓能用苹果不能(同一个无线安卓能上网,苹果不行)

  • 钉钉考试闪退后会自动提交吗(钉钉考试闪退后怎么恢复)

    钉钉考试闪退后会自动提交吗(钉钉考试闪退后怎么恢复)

  • 快手如何看对方在线不(快手如何看对方在不在线状态)

    快手如何看对方在线不(快手如何看对方在不在线状态)

  • 小度在家可以刷抖音吗(小度在家刷机固件)

    小度在家可以刷抖音吗(小度在家刷机固件)

  • 微信视频像素怎么调整(微信视频像素怎么办)

    微信视频像素怎么调整(微信视频像素怎么办)

  • 苹果11无法关机充电(苹果11无法关机一直转圈)

    苹果11无法关机充电(苹果11无法关机一直转圈)

  • 网络操作系统有哪些(网络操作系统有哪些基本功能)

    网络操作系统有哪些(网络操作系统有哪些基本功能)

  • vce al00是什么机型(vcr-al00什么型号)

    vce al00是什么机型(vcr-al00什么型号)

  • 华为自带音乐叫什么(华为自带的华为音乐怎么样)

    华为自带音乐叫什么(华为自带的华为音乐怎么样)

  • 华为变焦50倍手机是什么型号(华为50倍变焦不清楚)

    华为变焦50倍手机是什么型号(华为50倍变焦不清楚)

  • 苹果手机wps怎么以文件形式发送(苹果手机wps怎么保存到icloud)

    苹果手机wps怎么以文件形式发送(苹果手机wps怎么保存到icloud)

  • 魅族16屏幕辣眼睛吗(魅族16s屏幕刺眼)

    魅族16屏幕辣眼睛吗(魅族16s屏幕刺眼)

  • 电脑爱奇艺网页打不开怎么办(电脑爱奇艺网页版怎么投屏)

    电脑爱奇艺网页打不开怎么办(电脑爱奇艺网页版怎么投屏)

  • 滴滴代叫是怎么回事(滴滴代叫怎么操作)

    滴滴代叫是怎么回事(滴滴代叫怎么操作)

  • cool.exe是病毒文件吗 cool进程安全吗(coolmark是病毒吗)

    cool.exe是病毒文件吗 cool进程安全吗(coolmark是病毒吗)

  • 冰雪节上的冰雕艺术作品,加拿大渥太华 (© S. Garcia Cournoyer/Alamy)(冰雪节上的冰雕图片)

    冰雪节上的冰雕艺术作品,加拿大渥太华 (© S. Garcia Cournoyer/Alamy)(冰雪节上的冰雕图片)

  • 所得税率率
  • 记账凭证核算形式需要设置的凭证有
  • 前一年的发票第二年改抬头
  • 资产总额季度平均
  • 其他债权投资减值账务处理
  • 装饰设计事务所平面图
  • 可供出售金融资产计入什么科目
  • 增值税包括哪些税种
  • 对外支付佣金代扣代缴
  • 苗木销售免企业所得税吗
  • 公允价值变动损益是什么意思
  • 销售退货成本如何计算
  • 公司承担的个人所得税怎么做分录
  • 收到多开的发票会计上怎么入成本?
  • 会计帐务处理程序
  • 双系统跳过磁盘检测
  • 保险费做什么会计分录
  • macos monterey怎么降级
  • 2020 php 薪资
  • mac10.10.5系统
  • linux的grep命令使用
  • PHP:base64_decode()的用法_url函数
  • 纳税人解除劳动合同补偿
  • 购买材料支出属于资本性支出吗
  • 提坏账准备的调整分录
  • php基础入门教程
  • 一般纳税人辅导期最新规定
  • 哪些费用可以用医保
  • 贷款减值是什么会计科目
  • 国家规定免税饲料具体哪些产品
  • 代购货物的缴税情况
  • 可以享受企业所得税加计扣除的有
  • 马塔饰件怎么样
  • thinkphp wherein
  • php计算多个集合的数据
  • 关于我的家乡作文1000字
  • 土增税清算时怎么做会计分录
  • 毕业设计-基于组态软件的流量比值过程控制系统设计
  • 前端实现文件上传的命令
  • 认证系统维护费怎么算
  • tempdb数据库能删么
  • sqlserver2019查看表
  • 小规模纳税人三减一政策
  • 发票验旧验的是哪些发票
  • 母子公司之间借款要交税吗
  • 应交税费企业所得税科目
  • 公司财务报表中不设其他综合收益项目可以吗
  • 合作社分红计入什么科目
  • 分公司可以在银行贴现吗
  • 公司注销清算时个人股东如何计算个人所得税
  • 股权和出资的关系
  • 农产品开具发票税率是多少?
  • 小微企业可以享受六税两费吗
  • 筹建期间取得的利息收入 企业所得税
  • 单利率和复利率公式
  • 装修设计费多少合理
  • 在建工程怎么记账
  • 购买食品应注意哪些问题?
  • 惠普tpn-c126笔记本
  • 离线方式快速安装在哪里
  • mac怎么有线投屏到电视
  • 苹果macOS 14 正式发布
  • linux日志类型
  • camrec是什么文件
  • win10怎么安装运行库
  • rpm格式如何安装
  • w10 2021年更新
  • win7旗舰版使用ie8特别卡怎么回事?
  • Android自定义控件高级进阶与精彩实例
  • linux中执行.sh文件
  • Node.js中的核心模块包括哪些内容?
  • linux shell执行命令
  • Ubuntu修改用户名
  • unity怎么学
  • python从入门到精通
  • shell脚本中调用shell脚本
  • android动态添加view
  • python计算π值
  • adb查看ip地址
  • 电信追缴欠费的工作方案有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设