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

  • 手机金山文档编辑完怎么保存(手机金山文档编辑数字是乱码)

    手机金山文档编辑完怎么保存(手机金山文档编辑数字是乱码)

  • 荣耀无线耳机怎么连接手机(荣耀无线耳机怎么连接电脑)

    荣耀无线耳机怎么连接手机(荣耀无线耳机怎么连接电脑)

  • 如何格式化c盘(电脑硬盘如何格式化c盘)

    如何格式化c盘(电脑硬盘如何格式化c盘)

  • 小米蓝牙耳机声音小(小米蓝牙耳机声音小的解决方法)

    小米蓝牙耳机声音小(小米蓝牙耳机声音小的解决方法)

  • 朋友圈变成了一条线是不是被设置了(朋友圈变成了一条线是不是被设置了?)

    朋友圈变成了一条线是不是被设置了(朋友圈变成了一条线是不是被设置了?)

  • 三星安全模式什么意思(三星的安全模式有什么用)

    三星安全模式什么意思(三星的安全模式有什么用)

  • vivo禁止安装高危(vivo系统禁止安装高危)

    vivo禁止安装高危(vivo系统禁止安装高危)

  • se是苹果5还是苹果6(se是苹果5还是苹果8)

    se是苹果5还是苹果6(se是苹果5还是苹果8)

  • 微博如何发带播放键的音乐(微博如何发带播视频)

    微博如何发带播放键的音乐(微博如何发带播视频)

  • 苹果x锁屏延迟怎么解决(苹果锁屏延迟怎么设置)

    苹果x锁屏延迟怎么解决(苹果锁屏延迟怎么设置)

  • 小米10截屏快捷键(小米10截屏快捷方式在哪)

    小米10截屏快捷键(小米10截屏快捷方式在哪)

  • 群活跃度怎么提升?(个人群活跃度怎么提升?)

    群活跃度怎么提升?(个人群活跃度怎么提升?)

  • 苹果xr扩容稳定吗(苹果xr扩容稳定怎么设置)

    苹果xr扩容稳定吗(苹果xr扩容稳定怎么设置)

  • 用开发者模式伤手机吗(用开发者模式伤内存吗)

    用开发者模式伤手机吗(用开发者模式伤内存吗)

  • 100kva变压器额定电流是多少(100kva变压器额定高压电流是多少)

    100kva变压器额定电流是多少(100kva变压器额定高压电流是多少)

  • 抖音直播需要费用吗(抖音直播需要费流量吗)

    抖音直播需要费用吗(抖音直播需要费流量吗)

  • 去除图片水印的方法(去除图片水印的软件)

    去除图片水印的方法(去除图片水印的软件)

  • oppor11手机强制关机键(oppor11手机强制关机方法)

    oppor11手机强制关机键(oppor11手机强制关机方法)

  • erp账号是什么意思啊(erp帐号是什么意思)

    erp账号是什么意思啊(erp帐号是什么意思)

  • kindle每点一下就闪屏(kindle每按一下都闪屏)

    kindle每点一下就闪屏(kindle每按一下都闪屏)

  • 视频长了发不出去怎么办(视频长发不出去怎么剪辑)

    视频长了发不出去怎么办(视频长发不出去怎么剪辑)

  • 为什么用wps发文件是个链接(为什么用wps发文件会有wps的标签)

    为什么用wps发文件是个链接(为什么用wps发文件会有wps的标签)

  • linux下普通文件和目录文件区别详解(.linux文件)

    linux下普通文件和目录文件区别详解(.linux文件)

  • 【今日清明】哀悼为抗击新冠肺炎牺牲的烈士和逝世的同胞 (© Luca Flor/Shutterstock)(清明 哀思)

    【今日清明】哀悼为抗击新冠肺炎牺牲的烈士和逝世的同胞 (© Luca Flor/Shutterstock)(清明 哀思)

  • 常见经典目标检测算法(经典目标检测算法)

    常见经典目标检测算法(经典目标检测算法)

  • 主营业务成本大于生产成本
  • 付款申请单是原单据吗
  • u盘算固态吗
  • 收到项目投资款账务处理
  • 车辆审验费的会计分录
  • 电子承兑逾期提示付款说明怎么写
  • 餐饮发票个人抬头怎么写
  • 销项负数发票原发票还有用吗?
  • 单位支付给职工的一次性补助金怎么入账
  • 行政单位特殊人工手机电话费是否可以报销
  • 基础设施特许权包括
  • 将承兑汇票背书怎么操作
  • 增值税普通发票和电子普通发票的区别
  • 出口的进项发票如何记账
  • 广告费用的增值税税率
  • 该纳税人不属于经备案的二手车企业
  • 信托真实案例
  • 交到公户上的钱,还没到账可以退回吗?
  • 利润的三个计算口径
  • 企业停产没有收入,费用可以计入长期待摊费用吗
  • linux多线程运行
  • Win10任务栏图标居中
  • 杜鹃花怎么养家庭养法视频
  • PHP:Memcached::set()的用法_Memcached类
  • vue3 global
  • echarts饼图标题
  • pytorch的环境配置
  • thinkphp模型作用
  • 什么是企业所得税收入
  • 应交税费月末怎么结转分录
  • 策划费多少钱
  • 所得税汇算清缴调整项目
  • Switch Between Gnome And KDE Desktops In Ubuntu Or Kubuntu
  • 房地产项目转让流程
  • 增值税纳税人放弃免税权的规定
  • sqlserver避免死锁
  • 应收账款是指的资产吗
  • 核定征收和查账征收报税有区别吗
  • 公司卖出货物没有发票
  • 知识产权申请如何申请
  • 购买税控盘费用能全额抵扣吗
  • 白条入账的新会计政策
  • 应付利息属于什么负债
  • 主营业务成本账户属于什么账户
  • 小企业营业外支出坏账损失
  • 制造费用是借还是贷
  • 工伤误工费标准是按照社平工资来算的吗
  • sql没有数据库
  • mysql字符串类型有哪些
  • win7系统设置打印机共享
  • Ubuntu操作系统安全维护
  • win10 10月更新
  • winmysqladmin.exe - winmysqladmin进程是什么意思
  • 剑网端游吃电脑配置
  • win10自带的杀软叫什么
  • window10玩dnf怎么设置流畅
  • linux操作系统内核
  • Coroutine couldn't be started because the the game object 'GameController' is inactive!
  • bat删除所有文件
  • python爬虫教程
  • 一个android项目一般包含哪些目录?各有什么用途?
  • 后台运行bat定时器程序示例分享
  • js怎么检查错误
  • 安卓退出界面
  • unity游戏项目开发教程
  • jquery mobile
  • jQuery实现HTML表格单元格的合并功能
  • High Level Networking Concepts
  • javascript总结
  • jquery的css方法
  • jQuery AJAX timeout 超时问题详解
  • django for
  • js在div中添加div
  • 福建省个人所得税税率表查询
  • 国家税务局39号公告退税
  • 西安市港务区属于哪个街道办
  • 开展税务培训
  • 深圳市国家税务局电子税务局官网
  • 葫芦岛市税务局电话
  • 广西城建投资集团官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设