news 2026/4/17 4:13:27

一篇文章搞懂退出功能

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一篇文章搞懂退出功能

一、退出要实现的操作

(1)清理掉当前用户缓存数据

(2)清理掉权限相关配置

(3)返回到登录页

二、主动退出

主动退出指的是用户点击登录按钮之后退出

就是绑定点击退出事件,然后这个退出函数一般写在store中的user中的actions中,和登录的一样

import { removeAllItem } from '@/utils/storage' // 这个removeAllItem主要就是将window.localStorage.clear()清空 export default { state:(), mutations:(), actions:{ logout() { this.commit('user/setToken', '') this.commit('user/setUserInfo', {}) removeAllItem() router.push('/login') } } }

三、被动退出(token失效与单用户登录)

(1)主动处理——解决token失效,然后退出

在utils/auth.js中写入如下代码(处理token缓存时间)

import { TIME_STAMP, TOKEN_TIMEOUT_VALUE } from '@/constant' import { setItem, getItem } from '@/utils/storage' /** * 获取时间戳 */ export function getTimeStamp() { return getItem(TIME_STAMP) } /** * 设置时间戳 */ export function setTimeStamp() { setItem(TIME_STAMP, Date.now()) } /** * 是否超时 */ export function isCheckTimeout() { // 当前时间戳 var currentTime = Date.now() // 缓存时间戳 var timeStamp = getTimeStamp() return currentTime - timeStamp > TOKEN_TIMEOUT_VALUE }

在constant/index.js中

export const TIME_STAMP = 'timeStamp' export const TOKEN_TIMEOUT_VALUE = 1000 * 60 * 30 // 缓存时间30分钟

用户登录后设置时间

import { setTimeStamp } from '@/utils/auth' export default { namespaced: true, state: () => ({}), mutations: {}, actions: { login(context, userInfo) { 。。。 return new Promise((resolve, reject) => { 。。。 .then((data) => { 。。。 setTimeStamp() // 登录成功后设置时间戳 resolve() }) .catch((err) => { reject(err) }) }) }, 。。。 } }

在请求拦截器中主动介入(到达设置的时间节点后自动退出)

service.interceptors.request.use((config) => { 。。。 if (store.getters.token) { if (isCheckTimeout()) { store.dispatch('user/logout') return Promise.reject(new Error('token 失效')) } 。。。 } return config })

(2)被动处理——token失效

在响应拦截器中

service.interceptors.response.use( (response) => { 。。。 }, (error) => { if ( error.response && error.response.data && error.response.data.code === 401 ) { store.dispatch('user/logout') } ElMessage.error(error.message) return Promise.reject(error) } )

一般单用户登录也是用被动处理的,这里我也是在学习中,然后所用到的账号还是在多设备中可以登录的,处理单用户登录办法后续再补。


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 10:52:22

基于三菱PLC的智能温室大棚控制系统设计与实践:塑料大棚的环保控制技术解析

基于三菱PLC的温室大棚控制系统的设计塑料大棚温室控制系统设计 塑料大棚种菜最怕啥?半夜两点突然降温没人管,大中午太阳太毒忘记开遮阳帘。去年老王就因为这两件事赔进去三亩地的草莓苗,现在他大棚里装了个会自己思考的钢铁管家——基于三菱…

作者头像 李华
网站建设 2026/4/13 10:10:01

2025低代码平台实测盘点:5款工具的场景适配与选型指南

数字化转型的赛道上,低代码平台早已不是“可选项”而是“必选项”。今天结合市场份额、客户口碑与实测体验,为大家盘点5款各有千秋的低代码平台。 1、得帆云:大型企业的“复杂系统搭建神器” 得帆云的核心优势在于“hold住复杂场景”。它支…

作者头像 李华
网站建设 2026/4/16 20:19:30

牛批插件,让你的电脑瞬间丝滑!

啰嗦几句 浏览器插件可以实现资源嗅控、多线程下载、屏蔽广告、解除禁止复制等等功能,可以说插件是浏览器的灵魂! 而我们比较经常用到的插件有油猴、1DM、标签页等等。今天给大家推荐一款挺牛的拖拽预览的插件,非常方便,有需要的…

作者头像 李华
网站建设 2026/4/16 19:05:31

Docker入门

Docker是一款快速构建、运行、管理应用的工具自动搜索并下载应用镜像。镜像不仅包含应用本身,还包含应用运行所需要的环境,配置,系统函数库、Docker会在运行镜像时创建一个隔离环境,称为容器。镜像仓库:Docker Hub入门…

作者头像 李华
网站建设 2026/4/12 16:38:26

22、正则表达式:从基础到高级应用

正则表达式:从基础到高级应用 1. 正则表达式基础 正则表达式除了字面字符外,还包含元字符,用于指定更复杂的匹配规则。常见的元字符有: ^ $ . [ ] { } - ? * + ( ) | \ ,其他字符则被视为字面字符。不过,反斜杠字符在某些情况下用于创建元序列,也可让元字符被当作字…

作者头像 李华
网站建设 2026/4/12 23:09:57

取能模块:无源自取电创新解决方案

提及无源自取电,很多人会第一时间联想到智能手机的无线充电功能,原则上理解的没错,只是相较于无源自取电这种技术,二者本质上应用的领域有所区别。前者目前适用于中高压和低压输电线路上,以非接触式取能的核心优势&…

作者头像 李华