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

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

  • ipad怎么设置单个app密码(ipad怎么设置单个应用锁)

    ipad怎么设置单个app密码(ipad怎么设置单个应用锁)

  • wps自定义快捷键怎么设置(wps自定义快捷键的方法)

    wps自定义快捷键怎么设置(wps自定义快捷键的方法)

  • 荣耀30pro+充满电要多久呢(荣耀30pro+充满电要多久)

    荣耀30pro+充满电要多久呢(荣耀30pro+充满电要多久)

  • 剪映相册视频怎么加音乐(剪映相册视频怎么加字幕)

    剪映相册视频怎么加音乐(剪映相册视频怎么加字幕)

  • c语言中的函数不可以单独进行编译(c语言中的函数应由什么和函数体两部分组成)

    c语言中的函数不可以单独进行编译(c语言中的函数应由什么和函数体两部分组成)

  • 苹果微信怎么设置视频美颜视频(苹果微信怎么设置来电铃声)

    苹果微信怎么设置视频美颜视频(苹果微信怎么设置来电铃声)

  • 微信账号评估是什么意思(微信账号评估风险怎么弄)

    微信账号评估是什么意思(微信账号评估风险怎么弄)

  • 苹果7基带坏了还有修的必要吗(苹果7基带坏了怎么修)

    苹果7基带坏了还有修的必要吗(苹果7基带坏了怎么修)

  • 华为EMUI11升级时间(华为手机更新emui11)

    华为EMUI11升级时间(华为手机更新emui11)

  • 快手保证金500是一年吗(快手保证金500元有退成功的么)

    快手保证金500是一年吗(快手保证金500元有退成功的么)

  • 网络延迟怎么修复(如何修复网络延迟)

    网络延迟怎么修复(如何修复网络延迟)

  • win10激活了就是正版吗(win10激活后显示什么)

    win10激活了就是正版吗(win10激活后显示什么)

  • 华为p40没有耳机孔怎么办(华为mate50pro耳机)

    华为p40没有耳机孔怎么办(华为mate50pro耳机)

  • 微信与苹果5c不兼容(微信与苹果5c不同步信息)

    微信与苹果5c不兼容(微信与苹果5c不同步信息)

  • iphone6s卡屏滑动不了(6sp卡屏幕划不动)

    iphone6s卡屏滑动不了(6sp卡屏幕划不动)

  • 手机延迟拍照怎么设置(手机延迟拍照怎么关)

    手机延迟拍照怎么设置(手机延迟拍照怎么关)

  • 手机卡被锁定了怎么办(手机卡被锁定了还能解开吗)

    手机卡被锁定了怎么办(手机卡被锁定了还能解开吗)

  • excel怎么生成条形码(excel怎么生成二维码)

    excel怎么生成条形码(excel怎么生成二维码)

  • 华为mate30和pro有啥区别(mate 30和pro)

    华为mate30和pro有啥区别(mate 30和pro)

  • 相机扫一扫在哪(相机里面扫一扫在哪)

    相机扫一扫在哪(相机里面扫一扫在哪)

  • 手机收款语音如何放大(手机收款如何语音播报)

    手机收款语音如何放大(手机收款如何语音播报)

  • 手机网络拒绝接入 如何恢复(手机网络拒绝接入,连接失败是怎么回事)

    手机网络拒绝接入 如何恢复(手机网络拒绝接入,连接失败是怎么回事)

  • 识花君在微信哪里(微信小程序识花君如何使用?)

    识花君在微信哪里(微信小程序识花君如何使用?)

  • 抖音自动抢福袋脚本 直播间全自动辅助软件(抖音自动抢福袋挂机软件哪个好)

    抖音自动抢福袋脚本 直播间全自动辅助软件(抖音自动抢福袋挂机软件哪个好)

  • setconsole命令  设置系统终端(set命令用法)

    setconsole命令 设置系统终端(set命令用法)

  • 视同内销增值税怎么申报
  • 增值税税控开票软件怎么下载
  • 哪些进项税额可以抵扣销项税额
  • 个人出租住宅需要缴纳房产税吗
  • 消费税组成计税价格怎么理解
  • 增值税应纳税额的计算
  • 母公司借款给子公司现金流量表科目
  • 主营业务收入为什么记贷方
  • 零售盘点窍门
  • 以前年度已付的现金
  • 委托开发的软件产品即征即退
  • 公司购入汽车应交什么税
  • 股权的溢价是什么意思
  • 发票的单价开得太低了怎么办?
  • 个体户注销未分配利润要交个税吗
  • 残疾人保障金中上年在职职工人数怎么计算
  • 电器以旧换新的套路
  • 外购商品用于招待怎么做账
  • 公司预付的货款怎么做账
  • 递延资产和长期负债区别
  • 超市开具预付卡发票不征税发票上税吗
  • 留抵税额算进项税额吗
  • 代扣可以退款吗
  • 长期闲置的机器叫什么
  • 公司冲销费用凭证是什么
  • 人力资源劳务外包合同
  • 2021激活windows10
  • php数组函数题目
  • swoole和websocket的区别
  • Mac怎么更改默认打开方式
  • windows无法配置用户文件
  • 车辆违章罚款可以报销吗
  • messenger 是什么意思
  • 矿产资源补偿费是什么
  • 海关滞报金可以税前扣除吗 江苏
  • php阿里云oss
  • 什么是水利建设基金税
  • 汇兑差额如何计算
  • 行政单位捐赠会计分录怎么做的
  • phpsubstr方法参数
  • 谷歌浏览器调试窗口怎么放下面
  • face_recognition库采用了什么算法
  • chage -l命令
  • vue 快速上手
  • java泛型方法的使用
  • ps像素大小怎么调整不了
  • 应收账款项目的金额公式
  • 销售部门发生的商品维修费
  • 科技经费使用
  • 应付账款主要账户有哪些
  • 一般纳税人每月开票不能超过多少
  • 相同的商品附带不同的赠品发布
  • 现金折让的账务处理
  • 税盘进项税额怎么做
  • 公司自己制造设备怎么办
  • 代收第三方补偿什么意思
  • 出口退税进项票跨月勾选
  • 银行存款利息收入要交增值税吗
  • 股东将股权转让后是否还承担责任
  • 发票以外的其他发票
  • 银行固定资产有哪些
  • 库存商品账本填写样本
  • 什么叫商业会计
  • 安装windowsserver2008r2提示无法定位程序输入点
  • linux开机启动ftp
  • os x 10.11 el capitan系统安装图文教程
  • win10用360卫士好吗
  • svchost占用
  • win8系统字体大小设置
  • Win10怎么添加游戏
  • WIN10补丁白屏
  • cocos2dx 3.17
  • unity udim
  • 家字取名男孩名字
  • css 相对定位
  • javascript的for循环
  • python计算字符串长度的程序
  • 纳税申报表作废了怎么重新报?
  • 需要缴税多少钱一个月
  • 广东省纳税信用等级
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设