位置: 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年前端面试)

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

  • ps五角星形状在哪里(ps中五角星工具怎么弄)

    ps五角星形状在哪里(ps中五角星工具怎么弄)

  • 荣耀30pro支持sd卡扩展的吗(荣耀30Pro支持双WiFi吗?)

    荣耀30pro支持sd卡扩展的吗(荣耀30Pro支持双WiFi吗?)

  • 淘宝锁单是什么意思(淘宝 锁单)

    淘宝锁单是什么意思(淘宝 锁单)

  • 小米8老是自动关机(小米8老是自动关机怎么回事)

    小米8老是自动关机(小米8老是自动关机怎么回事)

  • 一般笔记本跑分多少万

    一般笔记本跑分多少万

  • 微机系统中的内存条指的是(微机中的内存主要包括rom ram对吗)

    微机系统中的内存条指的是(微机中的内存主要包括rom ram对吗)

  • 微信上有个耳朵的符号,怎么取消(微信上有个耳朵是什么意思怎么取消)

    微信上有个耳朵的符号,怎么取消(微信上有个耳朵是什么意思怎么取消)

  • ps保存什么格式可以再次编辑(cad导入ps保存什么格式)

    ps保存什么格式可以再次编辑(cad导入ps保存什么格式)

  • 物联卡和流量卡的区别(怎么分辨物联卡和流量卡)

    物联卡和流量卡的区别(怎么分辨物联卡和流量卡)

  • qq群直播可以回放吗(qq群直播回看在哪里)

    qq群直播可以回放吗(qq群直播回看在哪里)

  • 华为手机可以设置开机动画吗(华为手机可以设置下载软件需要密码吗)

    华为手机可以设置开机动画吗(华为手机可以设置下载软件需要密码吗)

  • 电脑开机按f8没反应怎么办(电脑开机按f8没用)

    电脑开机按f8没反应怎么办(电脑开机按f8没用)

  • 微信被临时限制登录什么时候就正常能用了(微信被临时限制社交场景需要多久)

    微信被临时限制登录什么时候就正常能用了(微信被临时限制社交场景需要多久)

  • 华为手表gt2音乐添加(华为手表GT2音乐下载)

    华为手表gt2音乐添加(华为手表GT2音乐下载)

  • 魅族16s有线性马达吗(魅族16s线性马达是什么轴的)

    魅族16s有线性马达吗(魅族16s线性马达是什么轴的)

  • 小米9pro怎么开启定位(小米9pro怎么开空调)

    小米9pro怎么开启定位(小米9pro怎么开空调)

  • 知乎网联系方式(知乎联系我们)

    知乎网联系方式(知乎联系我们)

  • 关闭蚂蚁森林有影响吗(关闭蚂蚁森林有什么好处)

    关闭蚂蚁森林有影响吗(关闭蚂蚁森林有什么好处)

  • 萤石云c6h复位健在哪里(萤石csc6h31wfr复位键)

    萤石云c6h复位健在哪里(萤石csc6h31wfr复位键)

  • v1829a是什么手机(v1820b是什么手机)

    v1829a是什么手机(v1820b是什么手机)

  • airpods寿命(airpods 寿命)

    airpods寿命(airpods 寿命)

  • QQ音乐无法播放怎么办(宝马车载qq音乐无法播放)

    QQ音乐无法播放怎么办(宝马车载qq音乐无法播放)

  • wps表格插一横线(wps表格里面加横线)

    wps表格插一横线(wps表格里面加横线)

  • NTFS文件夹权限使用说明(ntfs文件夹权限高于文件权限)

    NTFS文件夹权限使用说明(ntfs文件夹权限高于文件权限)

  • 怎么成为稚晖君?(稚晖君的学历)

    怎么成为稚晖君?(稚晖君的学历)

  • 天然气管网输送费收费标准
  • 异地建厂如何交社保
  • 进项税额转出如何申报
  • 收入准则范围内
  • 不计入销售收入
  • 不动产统一发票图片
  • 关税计入存货成本分录
  • 手撕发票怎么领取需要什么证件
  • 总资产报酬率计算举例
  • 如何少交点税
  • 定额发票验旧怎么操作
  • 到底如何理解参数方程
  • 个税当月计提还是下月
  • 未抵扣的进项税在资产负债表里怎么填
  • 公司一般户要做账吗
  • 腾讯电脑管家流量监控不显示
  • 驱动备份和还原工具软件有哪些
  • 发票专用章正规位置盖在哪里
  • 怎么修改以前年度的账
  • 鸿蒙系统蓝牙耳机声音小怎么办
  • 如何解决Windows10电脑卡顿现象
  • 不能运行windows10的设备有哪些
  • PHP:finfo_set_flags()的用法_fileinfo函数
  • 销售食品分录
  • 财务费用核算的内容没有
  • “Property or method “***“ is not defined on the instance but referenced during render.”报错的原因及解决方案
  • php激活码永久
  • laravel create
  • 信用减值损失会影响所有者权益吗
  • 小规模纳税人增值税免税政策
  • php十进制转二进制算法
  • php 取字符串 前几位
  • php的两种运行方式
  • vue开发环境和生产环境域名配置
  • nginx跨域配置详解
  • svg symbol
  • 农业合作社需要纳税吗
  • 给境外公司代扣代缴税款
  • 进销存使用视频
  • mysql命令大全手册
  • 欠对方钱对方公司已注销
  • 分公司可以独立签约吗
  • sqlserver数据库性能情况
  • 发票税率开错了3%开成5%怎么办?
  • 长期待摊费用怎么算出来的
  • 工会经费与残保金属于什么
  • 个人所得税完整申报流程
  • 小规模纳税人零申报可以持续多久
  • 企业所得税季度预缴纳税申报表
  • 基本户与一般户的区别与联系
  • 水电费没有票怎么做账
  • 增值税专用发票丢了怎么补救
  • 采购材料未付款填什么凭证
  • 高危险工作人员有什么意外险
  • 实收资本多少年到账
  • 固定资产已经超额融资了还能发放置换贷款吗
  • 记账凭证填制完毕
  • 维修费计入哪个账户
  • 装修费用税法规定有哪些
  • 事业单位开的发票
  • 会议费是指参加会议还是举办会议
  • 会计里面权益是什么
  • Linux/Mac MySQL忘记密码怎么办
  • Mysql inner join on的用法实例(必看)
  • mysql隐式类型转换规则
  • win10屏幕自动变黄
  • 还原windows是什么意思
  • mac怎么创建网络
  • mac使用命令
  • 从此学会隐藏悲伤全文
  • 生成系统健康报告怎么弄
  • linux shell命令大全
  • win8电脑管理员权限在哪里设置
  • win8.1怎么用
  • 备份mbr引导
  • unity3d界面
  • jquery插件大全
  • unity3d赛车游戏毕业设计
  • 安卓手机电驴
  • 生育登记网上服务大厅山东
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设