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

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

  • oppopfgm00是什么型号(oppo pefm00是什么手机)

    oppopfgm00是什么型号(oppo pefm00是什么手机)

  • p40只有4个摄像头吗(华为p40的3个摄像头只有中间的能照相吗)

    p40只有4个摄像头吗(华为p40的3个摄像头只有中间的能照相吗)

  • ios14添加桌面小组件的方法(ios14.2怎么设置桌面小组件)

    ios14添加桌面小组件的方法(ios14.2怎么设置桌面小组件)

  • 0000000024蓝屏怎样解决(00000024蓝屏)

    0000000024蓝屏怎样解决(00000024蓝屏)

  • 12340电话能打回去吗(12340会重打吗)

    12340电话能打回去吗(12340会重打吗)

  • 京东怎么拒收货品(京东拒收货物怎么退款申请)

    京东怎么拒收货品(京东拒收货物怎么退款申请)

  • 淘宝领不了优惠券是怎么回事(淘宝领不了优惠券系统休息中)

    淘宝领不了优惠券是怎么回事(淘宝领不了优惠券系统休息中)

  • 苹果x来电没声音怎么回事(苹果x来电没有声音)

    苹果x来电没声音怎么回事(苹果x来电没有声音)

  • 会员下载的视频不是会员了还可以看吗(会员下载的视频能分享吗)

    会员下载的视频不是会员了还可以看吗(会员下载的视频能分享吗)

  • 华为MAR一ALOO型号手机(华为型号mar-al00)

    华为MAR一ALOO型号手机(华为型号mar-al00)

  • opporeno2是不是5G手机(opporeno2是不是曲面屏)

    opporeno2是不是5G手机(opporeno2是不是曲面屏)

  • wifi20mhz和40mhz什么区别(wifi的20hz与40hz)

    wifi20mhz和40mhz什么区别(wifi的20hz与40hz)

  • 华为手机怎么卸载东西(华为手机怎么卸载手机管家)

    华为手机怎么卸载东西(华为手机怎么卸载手机管家)

  • wds状态未开启什么意思(wds未开启是什么意思路由器设置里)

    wds状态未开启什么意思(wds未开启是什么意思路由器设置里)

  • ipv4地址共有多少位(ipv4地址总数有多少)

    ipv4地址共有多少位(ipv4地址总数有多少)

  • 怎么把网页视频下载下来(怎么把网页视频保存到手机相册)

    怎么把网页视频下载下来(怎么把网页视频保存到手机相册)

  • macbook air照片怎么删(macbookair照片怎么删除)

    macbook air照片怎么删(macbookair照片怎么删除)

  • 小米3c路由器是多少兆(小米3c路由器是双频的吗)

    小米3c路由器是多少兆(小米3c路由器是双频的吗)

  • 抖音怎么把作品设置私密(抖音怎么把作品置顶)

    抖音怎么把作品设置私密(抖音怎么把作品置顶)

  • 苹果怎么关闭黑夜模式(苹果怎么关闭黑屏模式)

    苹果怎么关闭黑夜模式(苹果怎么关闭黑屏模式)

  • 通信协议有哪几种(通信协议有哪几类)

    通信协议有哪几种(通信协议有哪几类)

  • 荣耀v10升级9.1后增加了哪些功能(荣耀v10升级到9.0后怎样)

    荣耀v10升级9.1后增加了哪些功能(荣耀v10升级到9.0后怎样)

  • 苹果计时器在哪(苹果计时器怎么计时)

    苹果计时器在哪(苹果计时器怎么计时)

  • 拼多多工单怎么处理(拼多多工单怎么显示在电脑桌面)

    拼多多工单怎么处理(拼多多工单怎么显示在电脑桌面)

  • 微请注意!Win10 1903版将强制升级至1909或2004版本(win 10 请稍后)

    微请注意!Win10 1903版将强制升级至1909或2004版本(win 10 请稍后)

  • 角马群穿越在肯尼亚和坦桑尼亚之间的马拉河 (© zhengvision/Getty Images)(角马群的迁徙方向)

    角马群穿越在肯尼亚和坦桑尼亚之间的马拉河 (© zhengvision/Getty Images)(角马群的迁徙方向)

  • vue2.x的h函数(createElement)与vue3中的h函数(vue $函数)

    vue2.x的h函数(createElement)与vue3中的h函数(vue $函数)

  • 企业存款利息收入缴纳企业所得税吗
  • 个人所得税起征点2023税率表
  • 固定资产安装费用怎么处理
  • 企业异地迁移
  • 印花税申报成功后在哪缴税
  • 小规模没有成本票怎么做账
  • 公司投资款需要纳税吗
  • 预缴的附加税月末结转吗
  • 资产报废需要税务登记吗
  • 拖欠安装费
  • 退货折价的账务处理分录
  • 递延收益为什么是非流动负债
  • 在建工程在现金流量表中
  • 代开专用发票的企业如何享受小微免税优惠
  • 购房所需的税费种类和费用
  • 公司收承兑贴现的会计分录
  • 存货项目包括哪些具体内容
  • 个人可支配收入缩写
  • 未取得支付工程款的发票怎么做账?
  • 公司销售二手车账务处理
  • 企业债务重组损失的所得税前扣除
  • 小规模租赁税是怎么征收的
  • 合同副本和正本区别
  • 小规模企业季度超过30万,怎么收取增值税
  • 单位缴交的社保和医保还要交其他费用吗
  • 汇算清缴补交所得税的账务处理小企业会计准则
  • 对公直接转私人卡会怎么样
  • 公司支付给个人的货款怎么入账
  • 业绩补偿协议
  • 应发工资包含罚款吗
  • 企业残疾人保障金的缴纳标准
  • 付出去的款项退回怎么做账
  • 购买国外技术需要缴纳什么税
  • Mac怎么禁用icloud
  • 腾达路由器管理员密码
  • 变动成本法和完全成本法利润差异
  • 其他货币资金期末处理
  • 劳务公司开具劳务费发票
  • 医院的重要
  • 什么叫错账调整
  • 借支单还款后借支单要还么
  • 现金支付医保报销
  • 开发商没交税
  • 金银首饰消费税计税依据
  • paypal付款会自动换汇吗
  • php图片加水印实例分析
  • 补缴房产税和土地使用税会计分录
  • php提供的字符串函数
  • docker运行多个镜像
  • 如何构建自己的精神空间
  • 货真价实的话
  • 应交税费是借增还是贷增?
  • python tqdm是什么
  • 购买电梯会计账务处理
  • 车险 保险金额
  • 临时工资怎么核算
  • 收到汇算清缴退回的税款如何做账
  • 工程报废及毁损处理办法
  • 经济纠纷引发的抢劫
  • 增值税发票过期一年未认证怎么办
  • 小规模纳税人租赁发票税率是多少
  • 制造费用与辅助费用哪个先结转
  • sqlserver日志清理
  • 微软win8下载
  • windows server 2008 r2最大支持内存
  • 四步清理手机垃圾的方法
  • win7如何ghost
  • 为什么win7系统盘会自动满
  • cortana可以用于搜索本机文件吗
  • win8无法关机一直转圈
  • sql2000停止拒绝访问
  • linux tar命令安装
  • 解决出现的问题下一句,欢迎的语气
  • 页里面 CDATA的作用说明
  • opengl发光物体
  • javascriptwhile
  • unity异步加载场景
  • jq绑定事件的方法有哪些
  • android布局有哪些,它们的作用分别是?
  • 税务纪检部门
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设