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

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

  • 藏易通怎么添加家庭成员(藏易通怎么添加没有身份证的成员)

    藏易通怎么添加家庭成员(藏易通怎么添加没有身份证的成员)

  • 苹果手机指南针怎么校准(苹果手机指南针海拔怎么不显示)

    苹果手机指南针怎么校准(苹果手机指南针海拔怎么不显示)

  • 抖音链接淘宝的条件(抖音链接淘宝的橱窗是什么时候上线的)

    抖音链接淘宝的条件(抖音链接淘宝的橱窗是什么时候上线的)

  • iqoo和vivo质量一样吗(iqoo和vivo质量一样吗知乎)

    iqoo和vivo质量一样吗(iqoo和vivo质量一样吗知乎)

  • 安卓手机建议升级系统吗(安卓手机升级好吗?)

    安卓手机建议升级系统吗(安卓手机升级好吗?)

  • 蓝牙耳机微信语音没声音(蓝牙耳机微信语音不清晰)

    蓝牙耳机微信语音没声音(蓝牙耳机微信语音不清晰)

  • iphone管理付款方式打不开(iphone管理付款方式收不到验证码)

    iphone管理付款方式打不开(iphone管理付款方式收不到验证码)

  • 云台是什么设备(大疆云台是什么设备)

    云台是什么设备(大疆云台是什么设备)

  • b站录播在哪里看(b站录屏直播在哪)

    b站录播在哪里看(b站录屏直播在哪)

  • thinkpad和联想什么关系(thinkpad 和联想)

    thinkpad和联想什么关系(thinkpad 和联想)

  • 微信不显示图片是怎么回事(微信不显示图片怎么发朋友圈)

    微信不显示图片是怎么回事(微信不显示图片怎么发朋友圈)

  • 小米怎么用流量下载视频(小米怎么用流量卡)

    小米怎么用流量下载视频(小米怎么用流量卡)

  • mate30pro怎么设置熄屏快呼(mate30pro怎么设置来电闪光灯)

    mate30pro怎么设置熄屏快呼(mate30pro怎么设置来电闪光灯)

  • 苹果11怎么调来电闪光灯(苹果11怎么调来电铃声)

    苹果11怎么调来电闪光灯(苹果11怎么调来电铃声)

  • vivox21是什么充电接口(vivox21手机充电器是什么型号)

    vivox21是什么充电接口(vivox21手机充电器是什么型号)

  • 苹果13.1系统正式版什么时候上市(苹果13.1.3系统)

    苹果13.1系统正式版什么时候上市(苹果13.1.3系统)

  • ipad蜂窝版要插什么卡(ipad蜂窝版要插sim卡吗)

    ipad蜂窝版要插什么卡(ipad蜂窝版要插sim卡吗)

  • 苹果小球在哪里设置(苹果小球在哪里关闭)

    苹果小球在哪里设置(苹果小球在哪里关闭)

  • a1502是哪年的生产的(a1502pro是哪一年的款)

    a1502是哪年的生产的(a1502pro是哪一年的款)

  • 华为p30pro能拍多远(华为p30pro拍摄参数)

    华为p30pro能拍多远(华为p30pro拍摄参数)

  • qq空间如何打赏红包(qq空间如何打赏主播)

    qq空间如何打赏红包(qq空间如何打赏主播)

  • Dgservice.exe是什么进程 无法被结束的驱动精灵后门程序(dgservice.exe是什么文件)

    Dgservice.exe是什么进程 无法被结束的驱动精灵后门程序(dgservice.exe是什么文件)

  • 三种在首页调用留言本标题的方法(如何使用首页)

    三种在首页调用留言本标题的方法(如何使用首页)

  • 税金及附加二级明细
  • 土地使用税怎么征收标准
  • 网上认证勾选平台登录不成功
  • 销项税额是不是开出去的发票金额
  • 增值税一般纳税人是什么意思
  • 科技型中小企业条件
  • 工会差旅费如何做账
  • 发票抵税是指哪些内容
  • 营改增后受托代销手续费税率是多少?
  • 统借统还的所得税政策
  • 利润减库存为什么不等于现金
  • 作废发票如何管理
  • 代收水电费的会计分录
  • 银行存款余额调节表保管期限
  • 成本分析总结报告
  • 股东净利润是什么
  • 租入固定资产装修
  • 客户年会赞助是公司账户转嘛
  • windows11快捷操作
  • 西方会计要素有哪些
  • 共管帐户的特点是什么
  • 数人侵权行为的类型
  • PHP clearstatcache()函数详解
  • 个体公司转账给私人
  • atikdag.sys
  • PHP:class_implements()的用法_spl函数
  • 怎么更改win7
  • vue调整图标大小
  • 国有划拨土地给集体企业怎么办
  • 怎么算土地增值税
  • vscode插件vuter
  • python 量化
  • 图片美白ps
  • php实现文件上传的函数
  • 取得抵债资产支付的税费一般不包括下列哪种
  • 长期待摊费用的摊销分录
  • sql server 视图排序
  • 业务招待费的所得税扣除
  • 注销公司详细步骤
  • 个税 收入
  • 固定资产未登记入账
  • 业务招待费专票可以抵扣吗
  • 合同权利义务包含债务吗
  • 公司购买汽车如何抵成本
  • 五险一金没有金
  • 残保金缴纳计算方法2021
  • 预提费用为什么是负债
  • 实收资本印花税税率多少
  • 交易性金融资产的入账价值
  • 新建厂房需要缴纳什么税
  • 外聘人员个人简历
  • 出口退税进项票跨月勾选
  • 考试报名费都去哪了
  • 应收账款是哪个会计科目
  • 账务核对包括账表核对吗
  • sql语句汇总数据
  • SQL server字符串存数据库大还是二进制大
  • bios怎么恢复出厂设置教程
  • windows8.1使用教程
  • win7系统怎么看wi-fi密码
  • linux投屏快捷键
  • Win10 Redstone 11082视频快速上手:已知bug及新变化一览
  • 如何将电脑的win7系统变为win10
  • jquery对动态生成的进行操作
  • javascript HTML5 Canvas实现圆盘抽奖功能
  • 使用的拼音
  • css checked
  • django内置组件
  • jquery技巧
  • js实现滑动开关功能
  • unity2019texture
  • python装饰器与递归算法详解
  • 用js设置颜色
  • jquery鼠标移入移出切换图片
  • android开发—01开发环境的搭建
  • js框架开发实例
  • android软件开发实例
  • 税务局发票邮寄回来怎么读入?
  • 下列关于消费税委托加工说法正确的是
  • 陕西的发票在哪里领取
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设