位置: IT常识 - 正文

前端登录退出:处理Token问题(获取、缓存、失效处理)以及代码实现(前端登录退出怎么操作)

编辑:rootadmin
前端登录退出:处理Token问题(获取、缓存、失效处理)以及代码实现 目录一、什么是Token二、获取token三、Token失效处理注意点1、主动退出2、Token过期① 逻辑图②方案③代码实现3、被人顶号① 逻辑图② 方案③代码实现一、什么是Token

推荐整理分享前端登录退出:处理Token问题(获取、缓存、失效处理)以及代码实现(前端登录退出怎么操作),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:登录前端后端怎么做的,前端点击登录弹出登录窗口,前端登录跳转,前端登录退出怎么操作,前端登录退出方法,前端登录退出怎么操作,前端退出登录需要调接口嘛,前端登录退出思路,内容如对您有帮助,希望把文章链接给更多的朋友!

Token是服务端生成的一串字符串,当用户第一次登陆成功后,服务器会生成一个token,并将其返回给客户端。 当用户再次向服务器请求数据时,只需要携带着token请求数据即可,无需再次登陆用户名和密码 目的 通过token做一层数据拦截,可以减少数据库请求次数,减缓服务器压力

二、获取token

当用户第一次登陆成功之后,后台会返回一个token给到客户端,前端将token缓存到本地,然后每次发请求时需要在 header 里边带上 token,这个时候本地的 token 和后台数据库中的 token 进行一个验证,如果两者一致,则请求成功,否则失败。

三、Token失效处理

既然前后端通过token交互,如果一直有效,会有安全风险,所以我们需要在客户端进行一下token的时间检查 服务器的token一般不会设置太长,根据实际一般是1-7天,没有一个token是永久的,永久的token就相当于一串永久的密钥,是不安全的。

token失效一般用两种情形: ① 主动退出:用户点击退出登录按钮后退出 ② 被动退出:token过期,或被人“顶号”退出

注意点前端登录退出:处理Token问题(获取、缓存、失效处理)以及代码实现(前端登录退出怎么操作)

无论什么方式退出token,在用户退出时,所需要执行的操作都是固定的 1、清理掉当前用户的缓存数据 2、清理掉相关权限的配置 3、返回到登录页面

1、主动退出

用户主动点击退出功能实现 user.js

// 获取退出登录logout(context) { context.commit("removeToken"); // 删除token context.commit("reomveUserInfo"); // 删除用户信息},2、Token过期① 逻辑图

②方案

在用户登录时,记录当前的登录时间 制定一个token时效时长 在接口调用时,根据当前时间对比登录时间,看是否超过了时效时间 如果未超过,则正常进行后续操作,如果超过,则进行退出登录操作

③代码实现

user.js

// 获取登录信息async login(context, data) { const result = await loginInfo(data); context.commit("setToken", result); setTimeStamp(); // 写入时间戳},

auth.js

import Cookies from "js-cookie";const timeKey = 'liqi6limi-timestamp-key' // 设置一个独一无二的key// 获取时间戳export function getTimeStamp() { return Cookies.get(timeKey)}// 设置时间戳export function setTimeStamp() { Cookies.set(timeKey, Date.now())}// 设置超时时间export const TimeOut = 3600; // 是否超时export function IsCheckTimeOut() { var currentTime = Date.now(); // 当前时间戳 var timeStamp = getTimeStamp(); // 缓存时间戳 return (currentTime - timeStamp) / 1000 > TimeOut;}

request.js

import store from "@/store";import axios from "axios";import { getTimeStamp,IsCheckTimeOut } from "@/utils/auth";import router from "@/router";// 创建axios实例const service = axios.create({ baseURL: "/api", timeout: 5000,});// 请求拦截器service.interceptors.request.use( (config) => { // 是否存在token if (store.getters.token) { if (IsCheckTimeOut()) { store.dispatch("user/logout"); // 退出登录的action router.push("/login"); // 跳转到登录页 return Promise.reject(new Error("token超时了")); // 抛出的错误,会在响应拦截器的错误捕捉中捕捉到 console.log("超时"); } config.headers["Authorization"] = `Bearer ${store.getters.token}`; // 如果token存在 注入token } return config; // 必须返回配置 }, (error) => { return Promise.reject(error); });3、被人顶号① 逻辑图

② 方案

后端返回数据时,会返回特定的状态码通知前端 当前端接收到特定状态码时,表示遇到了特定状态:此时进行退出登录处理

③代码实现// 响应拦截器service.interceptors.response.use( (response) => { // axios默认加了一层data const { success, message, data } = response.data; // 要根据success的成功与否决定下面的操作 if (success) { return data; } else { // 业务已经错误了 Message.error(message); // 提示错误消息 return Promise.reject(new Error(message)); } }, (error) => { // error 信息 里面 response的对象 if ( error.response && error.response.data && error.response.data.code === 10002 ) { // 当等于10002的时候 表示 后端告诉我token超时了 store.dispatch("user/logout"); // 登出action 删除token router.push("/login"); } else { Message.error(error.message); // 提示错误信息 } return Promise.reject(error); });
本文链接地址:https://www.jiuchutong.com/zhishi/284130.html 转载请保留说明!

上一篇:2023前端面经(面试准备+面试题)(2020年前端面试)

下一篇:便秘怎么办——居家自己治疗便秘最佳方法(便秘怎么办 女性)

  • 未来的SEO:移动页面决定桌面搜索排名(移动发展的趋势2020)

    未来的SEO:移动页面决定桌面搜索排名(移动发展的趋势2020)

  • 经典励志故事:一枚戒指(经典励志故事大全)

    经典励志故事:一枚戒指(经典励志故事大全)

  • 华为nova9耳机孔在哪里(华为nova9耳机孔为什么小)

    华为nova9耳机孔在哪里(华为nova9耳机孔为什么小)

  • win10数字权利激活的弊端(win10数字权利激活洗白)

    win10数字权利激活的弊端(win10数字权利激活洗白)

  • 微信发word格式乱了(微信发word文档)

    微信发word格式乱了(微信发word文档)

  • 探探喜欢数突然不涨了(为什探探喜欢我的人会减少)

    探探喜欢数突然不涨了(为什探探喜欢我的人会减少)

  • 微信怎么不显示忙线中(微信怎么不显示有几条新消息)

    微信怎么不显示忙线中(微信怎么不显示有几条新消息)

  • 苹果手表充电一亮一灭(苹果手表充电一直闪烁显示苹果标志)

    苹果手表充电一亮一灭(苹果手表充电一直闪烁显示苹果标志)

  • 华为p30屏幕上有个点点怎么关(华为p30屏幕上有个指纹图案怎么关)

    华为p30屏幕上有个点点怎么关(华为p30屏幕上有个指纹图案怎么关)

  • ipad3微信版本低登录不了怎么办(ipad3微信版本低登录不了)

    ipad3微信版本低登录不了怎么办(ipad3微信版本低登录不了)

  • 钉钉打卡会暴露位置吗(钉钉打卡会暴露手机号吗)

    钉钉打卡会暴露位置吗(钉钉打卡会暴露手机号吗)

  • 华为手机静音闹钟会响吗(华为手机静音闹钟还会有声音吗)

    华为手机静音闹钟会响吗(华为手机静音闹钟还会有声音吗)

  • 打印机碳带回收轴不卷(打印机碳带回收轴不卷视频)

    打印机碳带回收轴不卷(打印机碳带回收轴不卷视频)

  • 微博账号格式错误什么意思(微博手机号格式错误)

    微博账号格式错误什么意思(微博手机号格式错误)

  • 笔记本鼠标突然不能用了(笔记本鼠标突然变得很迟钝为什么)

    笔记本鼠标突然不能用了(笔记本鼠标突然变得很迟钝为什么)

  • vivo演示机是什么意思(vivo 演示机)

    vivo演示机是什么意思(vivo 演示机)

  • 多媒体的数据压缩方法有(多媒体数据压缩技术的三个主要指标)

    多媒体的数据压缩方法有(多媒体数据压缩技术的三个主要指标)

  • 华为nova6什么时候开售(华为nova6什么时候出)

    华为nova6什么时候开售(华为nova6什么时候出)

  • 压缩文件要下载什么软件(压缩文件要下载什么才能解压)

    压缩文件要下载什么软件(压缩文件要下载什么才能解压)

  • vivos1有没有闪充(vivos1闪充怎么突然没有了)

    vivos1有没有闪充(vivos1闪充怎么突然没有了)

  • 华为nova5pro充电器多少瓦(华为nova5pro充电器型号参数)

    华为nova5pro充电器多少瓦(华为nova5pro充电器型号参数)

  • 迅捷cad和autocad区别(迅捷cad和浩辰哪个好用)

    迅捷cad和autocad区别(迅捷cad和浩辰哪个好用)

  • 微信发的文件怎么撤回(微信发的文件怎么打印出来)

    微信发的文件怎么撤回(微信发的文件怎么打印出来)

  • 无线键盘接收器丢了怎么办(无线键盘接收器多少钱一个)

    无线键盘接收器丢了怎么办(无线键盘接收器多少钱一个)

  • ECharts 引入中国地图和区域地图(echarts怎么引入)

    ECharts 引入中国地图和区域地图(echarts怎么引入)

  • 审计合同需要交税吗
  • 我可以通过什么知道明天的天气情况
  • 金蝶能够反年结账吗
  • 赠送的代金券属于销售费用吗?
  • 红字专用发票信息表用什么纸打印
  • 去年的进项发票今年还能抵扣吗
  • 开具不规范的发票
  • 服务性单位从事的是餐饮中介服务
  • 无形资产是金融性资产还是经营性资产
  • 企业取得5%的房产增值税发票是否可以抵扣呢?
  • 企业贷款核销条件
  • 现金支票作废需要签字吗
  • 服务费可以不退吗
  • 农业企业土地租赁费账务处理
  • 增值税专用发票有效期是多长时间
  • 会务费发票税点是多少
  • 不付供应商尾款了怎么清账
  • 外经证过期没报验
  • 上月销项税额错了怎么修改凭证?
  • 销项税现金流量表在附表中如何列示
  • 一般纳税人简易计税会计分录
  • 向非绑定账户转账超限是什么意思
  • 其他所得是什么意思
  • 免费样品销售给客户怎么入账
  • Win10专业版网络连接不上
  • kb4598481是什么
  • 应付票据转让会计分录
  • 装饰工程施工包括什么
  • Laravel中七个非常有用但很少人知道的Carbon方法
  • 企业工商年检什么意思
  • 汇兑损益计入什么科目
  • 会计科目分类有几种方法
  • 共识算法主要解决什么问题
  • ml神经网络
  • php判断包含指定内容
  • php生成唯一id
  • 注册一个公司没有流水可以吗
  • 货代一般一个柜利润多少
  • 购物赠品的处理流程
  • 企业金融资产包括
  • sqlserver2005导出数据
  • 进项税金抵扣
  • 职工工伤住院期间的各项费用由谁负责
  • 税款减半征收如何申报
  • 高新技术企业核心人才保险
  • 实收资本的入账金额包括消费税吗
  • 公司股权变更如何合理避税
  • 科研专用费是什么
  • 收到去年所得税退税款会计分录
  • 股东退股如何清算
  • 处置固定资产的增值税怎么处理
  • 轿车折旧年限为几年
  • mysql tmp_table_size和max_heap_table_size大小配置
  • sql实现分页查询语句
  • Win10 Mobile Build 10549正式推送:须回滚到WP8.1升级
  • ssh访问windows
  • 快速任务栏
  • linux没有ssh
  • win8.1怎么设置自动关机
  • win10周年更新版是什么意思
  • win8网络设置
  • win10如何移动应用程序
  • linux查看nginx配置文件
  • unity unity3d
  • unity进阶之路
  • 文本框后缀
  • nodejs bff
  • 置顶在线
  • cocos2d android
  • 谈一谈js消息机制的理解
  • bootstrap需要学多久
  • javascript常用类型
  • 链接的链
  • shell打开日志文件
  • shell脚本 -ne 0
  • javascript零基础入门书籍
  • 禁止所有陌生人的来电设置
  • 贷款利息收入增值税税率2023
  • 报企业增值税
  • 刚注册了一家深圳公司
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设