在前后端是以token(令牌)的形式交互的,既然是token,是有过期时间的(为了接口数据的安全,
服务器的token不会设置太久,根据需要一般是1-7天),没有一个token是永久的,永久的token相当
于一串永久密码,是不安全的。

登录场景:

既然token有过期时间,那么问题来了:

一、前后端交互过程中token如何存储?
1.存在cookie中

cookie的大小约4k,兼容性在IE6以及以上都兼容,在浏览器和服务器之间来回传递,因此他得在服务器的环境下运行,而且可以设置过期时间,默认过期时间是session会话结束。

2.存在localstorage中

localstorage的大小约5M,兼容性在IE7以上都兼容,有浏览器就可以,不需要在服务器环境下运行,会一直存在,除非手动清除。

二、token过期时,前端如何处理?
1.跳回登录页面重新登录(不推荐)

在vue中我们可以在axios拦截器中这样写:
instance.interceptors.response.use(function (response) {// 对响应数据做点什么return response.data},function (error) {if (error.response) {if (error.response.status === 401) {Message.error('登陆过期请重新登陆!')setToken('')router.push({name: 'login'})}}}// 对响应错误做点什么return Promise.reject(error.response)}
)

2.重新获取token

出于本文的目的,我们将关注最常见的两种令牌类型:访问令牌和刷新令牌。
no.1访问令牌携带必要的信息以直接访问资源。换句话说,当客户端将访问令牌传递给管理资源的服
务器时,该服务器可以使用令牌中包含的信息来决定客户端是否被授权。访问令牌通常具有到日期
并且是短暂的。

no.2刷新令牌包含获取新访问令牌所需的信息。换句话说,每当访问令牌需要访问特定资源时,客户
端可以使用刷新令牌来获得由认证服务器发布的新访问令牌。常见用例包括在旧的访问令牌过期后
获取新访问令牌,或者首次访问新资源。刷新令牌也可以过期,但相当长寿。刷新令牌通常受到严
格的存储要求,以确保它们不会泄露。

总结:服务器生产token的过程中,会有两个时间,一个token失效时间,一个是token刷新时间;
刷新时间比失效时间长,当用户的token过期时,你可以拿着过期的token去换新的token,来保持用
户的登录状态,当然你这个过期token的过期时间必须在刷新时间之内,如果超出了刷新时间,那么
返回仍然是401。

三、如何实现无感知刷新?

1.在axios的拦截器中加入token刷新逻辑;
2.当用户token过期时,去向服务器请求新的token;
3.将旧的token替换为新的token;
4.继续用户当前的请求;
 // 在axios的拦截器中加入token刷新逻辑:instance.interceptors.response.use(function(response){// 对响应数据做些什么return response.data;},function(error){if(error.response){if(error.response.status===401){//  如果当前路由不是login,并且用户有记住密码操作,那么去请求刷新tokenif(router.currentRoute.name!=='login'){if(getRemember()&&getRefreshToken()){return doRequest(error)}else{Message.error('登录过期请重新登录!')setToken('')router.push({name:'login'})}}}}// 对响应错误做些什么return Promise.reject(error.response)})async function doRequest(error){const data = await store.dispatch('refreshToken');let {token_type:tokenType,access_token:accessToken}=data;let token = tokenType+accessToken;let config = error.response.config;config.headers.Authorization = token;const res = await axios.request(config)return res}// refreshToken中重新设置了token和refresh_Tokencommit('setToken',{token,expiresIn})setRefresToken(token,refreshThl/(60*60*24))
总结:
弄两个token,一个负责鉴权token:access_token,一个负责刷新得token:refresh_token,每次请求带上这两个token,后端拦截器判断,先判断鉴权token是否有效,如果有效允许访问,如果过期,就判断刷新token是否有效,如果有效,返回指定状态码,然后让前端根据这个状态码去调用刷新token接口。如果刷新token失效,就提示需要重新登录!

整体思路

前端token知识梳理:token如何存储?token过期如何处理?如何无感知刷新token?相关推荐

  1. 使用Axios进行无感刷新Token

    前言 本人在开发项目时,在做登录模块时,参考了oauth2,在用户认证成功后会返回给前端一些令牌相关数据.接下来,再用进行接口请求时,前端根据令牌数据进行一系列的判断,然后做出最好的选择. 举个例子: ...

  2. 实现无感刷新token我是这样做的

    大家好,我是漫步,今天来分享一个登录常常遇到的难题,即登录超时时间与安全性的纠结问题. 原文: https://juejin.cn/post/6983582201690456071 前言 最近在做需求 ...

  3. Laravel6通过jwt(tymon/jwt-auth)实现API用户无感刷新TOKEN

    Laravel6通过jwt实现API用户无感刷新TOKEN 1.TOKEN是什么 2.jwt是什么 3.jwt安装&配置 3.1.通过composer安装 3.2.发布配置 3.3.生成加密密 ...

  4. Vue 无感刷新token

    关于无感刷新的理解:  实现token无感刷新对于前端来说是一项非常常用的技术,其本质是为了优化用户体验,当token过期时不需要用户跳回登录页重新登录,而是当token失效时,进行拦截,发送刷新to ...

  5. 实现无感刷新 token 我是这样做的

    原文: https://juejin.cn/post/6983582201690456071 前言 最近在做需求的时候,涉及到登录token,产品提出一个问题:能不能让token过期时间长一点,我频繁 ...

  6. token过期怎么办 无感刷新token

    (1)可以通过响应拦截器或者全局前置守卫强制跳转登录页 // 全局前置守卫 router.beforeEach((to, from) => {let token = sessionStorage ...

  7. 关于无感刷新Token,我是这样子做的

    本文正在参加「金石计划 . 瓜分6万现金大奖」 什么是JWT JWT是全称是JSON WEB TOKEN,是一个开放标准,用于将各方数据信息作为JSON格式进行对象传递,可以对数据进行可选的数字加密, ...

  8. uniapp 实现无感刷新token, 适应大多数项目

    不管你是用taro uni 还是vue-cli 或者 react-cli 刷新token这块一通百通 本质上 都一样 我之前讲了一个是 在响应拦截哪里做token刷新 其实这样做还是不好的,因为这样我 ...

  9. 无感刷新token方法

    通常,对于一些需要记录用户行为的系统,在进行网络请求的时候都会要求传递一下登录的token.不过,为了接口数据的安全,服务器的token一般不会设置太长,根据需要一般是1-7天的样子,token过期后 ...

  10. 前端token知识梳理:token如何存储?token过期如何处理?如何无感刷新token?

    在前后端是以token的形式交互,既然是token,那么肯定有它的过期时间(为了接口数据的安全,服务器的token一般不会设置太长,根据需要一般是1-7天的样子),没有一个token是永久的,永久的t ...

最新文章

  1. 机器学习算法与理论用到的数学知识
  2. elasticsearch入门hello world (macos)【一】下载运行
  3. 横竖三个数的和相等_怎样证明 0.999… = 1?数值上是相等的,那么两者的区别是什么?...
  4. Android BroadcastReceiver广播详解
  5. 多帧点云数据拼接合并_PCL点云处理实践(二):点云的处理和拼接
  6. 计算机专业好还是铁道运输管理好,铁道运输管理专业主要是干什么的?
  7. 第二届数据科学家大会 专家豪华阵容公布!
  8. Excel2010--在指定的范围内添加随机数
  9. 根据接口文档中的入参,生成自动化测试用例中的异常测试用例,包含用例描述,用例数据
  10. 上岗乌镇大会安防的智慧警眼“云镜”,是谁家的AR眼镜?
  11. 《从零开始学Swift》学习笔记(Day 14)——字符串的插入、删除和替换
  12. python制作中秋贺卡图片_中秋贺卡手工制作图片
  13. hdu题目分类--第二版
  14. html2canvas区域截屏,vue实现网页区域截屏(结合html2canvas,pdf.js)
  15. opening V4L
  16. 一些 金融知识 小结
  17. matlab区分连续波与脉冲,【求助】连续波多谱勒和脉冲波多谱勒的区别
  18. 语音处理/语音识别基础(三)- 声音的特征和声音的能量
  19. 奔驰采用鸿蒙系统,华为10分钟秒充190公里模块出口奥地利,奔驰使用鸿蒙系统!...
  20. 11 项目的工程文件存在哪里

热门文章

  1. 动画状态机相同而动画不同的角色,需要用到AnimatorOverrideController 动画器重写控制器
  2. 学习新时代编程语言Rust-12小胖的裤子
  3. linux网卡变成fe80,linux的ifconfig命令出现inet6fe80的解决方案.docx
  4. Utorrent死机恢复种子下载
  5. 计算机课用英语怎么说cute,it/cute是什么意思
  6. windows10 C盘满了,怎么处理
  7. OpenShift 4 之让Route只运行在集群中Infra节点
  8. 狂野飙车3 java,都市赛车3/蹦蹦球历险_诺基亚 N85_手机其它OS-中关村在线
  9. 满足条件的数累加(YZOJ-1066)
  10. 华为智能汽车产业研究与投资机会分析