位置: 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)

  • 手机酷狗如何导入本地音乐(手机酷狗如何导入文件音频)

    手机酷狗如何导入本地音乐(手机酷狗如何导入文件音频)

  • 荣耀x10指纹解锁方式是什么(荣耀x10指纹解锁怎么没有了)

    荣耀x10指纹解锁方式是什么(荣耀x10指纹解锁怎么没有了)

  • 华为p30来电没有声音(华为p30来电没有铃声)

    华为p30来电没有声音(华为p30来电没有铃声)

  • 网络身份验证出现问题(网络身份验证出现问题是什么原因)

    网络身份验证出现问题(网络身份验证出现问题是什么原因)

  • 微信如何取消爱奇艺自动续费(微信如何取消爱奇艺会员续费)

    微信如何取消爱奇艺自动续费(微信如何取消爱奇艺会员续费)

  • 手机qq邮箱文件打不开怎么办(手机qq邮箱文件中转站怎么重命名)

    手机qq邮箱文件打不开怎么办(手机qq邮箱文件中转站怎么重命名)

  • 系统检测交易异常暂不允许在此群发红包(系统检测交易异常原因)

    系统检测交易异常暂不允许在此群发红包(系统检测交易异常原因)

  • 蓝牙耳机自动关机解除(蓝牙耳机自动关机后开不了机)

    蓝牙耳机自动关机解除(蓝牙耳机自动关机后开不了机)

  • qq邮箱过期的超大附件可以恢复吗(qq邮箱过期的可以恢复吗)

    qq邮箱过期的超大附件可以恢复吗(qq邮箱过期的可以恢复吗)

  • 什么叫手机彩虹屏(手机彩虹图片大全)

    什么叫手机彩虹屏(手机彩虹图片大全)

  • 快手昵称后面的数字代表什么(快手昵称后面的数字名)

    快手昵称后面的数字代表什么(快手昵称后面的数字名)

  • 升级手机系统有什么影响(升级手机系统有什么用)

    升级手机系统有什么影响(升级手机系统有什么用)

  • 初始化失败什么意思(初始化失败怎么回事)

    初始化失败什么意思(初始化失败怎么回事)

  • 发出去的抖音怎么重新编辑(发出去的抖音怎么改封面)

    发出去的抖音怎么重新编辑(发出去的抖音怎么改封面)

  • oppoa5可以用5g网络吗(oppoa5支持5gwifi吗)

    oppoa5可以用5g网络吗(oppoa5支持5gwifi吗)

  • 微信文件打不开要下载什么软件(微信文件打不开显示用其他应用打开)

    微信文件打不开要下载什么软件(微信文件打不开显示用其他应用打开)

  • 乐视手机怎么解屏幕锁(乐视手机怎么解锁)

    乐视手机怎么解屏幕锁(乐视手机怎么解锁)

  • 微信读书挂着算时长吗(微信读书kundle)

    微信读书挂着算时长吗(微信读书kundle)

  • nas硬盘和普通硬盘区别(nas硬盘和ssd硬盘区别)

    nas硬盘和普通硬盘区别(nas硬盘和ssd硬盘区别)

  • 微信群收款钱去哪里了(微信群收款的钱)

    微信群收款钱去哪里了(微信群收款的钱)

  • 换了新手机怎么把电话号码转过去(换了新手机怎么配对iphonewatch)

    换了新手机怎么把电话号码转过去(换了新手机怎么配对iphonewatch)

  • Mozilla.exe是什么进程 有什么作用 Mozilla进程查询(mozilla是什么文件)

    Mozilla.exe是什么进程 有什么作用 Mozilla进程查询(mozilla是什么文件)

  • 前端请求中body和query传参(前端请求方式)

    前端请求中body和query传参(前端请求方式)

  • 帝国cms如何导入自定义js(帝国cms导入模板后怎样调用)

    帝国cms如何导入自定义js(帝国cms导入模板后怎样调用)

  • 个人独资企业是否享受六税两费政策
  • 年末发票
  • 税务师职业考试
  • 房产税和车船税计入应交税费吗
  • 特许权使用费收入
  • 固定成本和变动成本之和称作
  • 中介费要求开发票中介公司不开
  • 没有车加油费可以入账吗
  • 小企业会计准则会计科目表
  • 销售企业资金风险点有哪些呢
  • 销售预付卡的成本是什么
  • 企业如何进行利润分配的会记处理
  • 工程完工进项税税务局不给退,走那个科目销毁
  • 证券投资基金管理办法
  • 递延所得税收益计算公式
  • 借钱注册公司会计分录
  • 销售费用广告费存在哪些问题
  • 应纳税所得额要减所得税费用吗
  • 企业所得表怎么填写
  • 加工贸易企业如何财务管理账务流程
  • 支付短期借款利息
  • 销售东西的物流叫什么
  • 如何使用腾讯电子签维护自己的权益
  • win10我的电脑图标不见了怎么恢复原状
  • 英雄联盟登录失败7502013
  • mac怎么传文件到百度网盘上
  • win11如何多窗口
  • win10家庭最新版
  • win10启用网络发现保存后又变成了关闭
  • 在win7中,如何创建一个TXT文件
  • 农产品销售发票抵扣政策
  • 合并财务报表抵消损益怎么理解
  • 生产加工型企业安全隐患排查内容
  • 远期外汇交易会有风险吗
  • vue的watch不生效
  • 预收账款通俗易懂的说法
  • php请求https
  • 可视化大屏的几种模式
  • php 自动化测试
  • php中session什么意思
  • 专用发票密码区模糊了影响报销吗
  • 用友软件怎么删除已经建立的账套
  • npm ERR! notarget No matching version found for xxx@^1.0.64. npm 插件安装失败
  • windowlocation用法
  • js中数组操作
  • centos7编译安装内核
  • 如何在国家税务局增值税纳税申报
  • 生产型外资企业
  • 建设单位和施工单位的责任和义务
  • 银行承兑汇票到期怎么兑现
  • mysql百万级数据分页查询优化
  • 给客户的回扣如何做账
  • 业务招待费列支不规范
  • 一般纳税人无形资产税率
  • 广告设计要交文化事业建设
  • 投资收益记账
  • 固定资产的期末余额反映固定资产原值的结余额
  • 母子公司之间无偿划转固定资产
  • 农场有多少只鸡
  • 本票包括哪些
  • 文化事业建设费逾期未申报怎么办
  • vhd 打开
  • win10创建家庭
  • wps文字打印不清楚怎么办
  • windows无法升级
  • win8怎么创建宽带连接
  • 安卓图像处理app
  • 用<TABLE>语句来实现圆角表格可以省去制作圆角图片之苦!
  • unity3D游戏开发
  • html用div来写表格
  • jquery prompt
  • Unity NGUI添加事件监听(转摘)
  • jQuery用FormData实现文件上传的方法
  • mkdirs linux
  • unity3d文件怎么查看和修改
  • jquery的实现原理
  • 在androidstudio中,如何改变图片的位置
  • ca证书怎么下载安装
  • 重庆车位过户需要多久时间
  • 国税局招录条件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设