vue项目:token过期后自动更新token,提示登陆过期并退出登录,跳转到登录页面重新登录

目录

在src/router/index.js文件中编写代码

启动项目,按下F12键,在控制台中输入清除token的命令模拟token过期的情况:


确保你安装了elementui,因为提示登录过期的弹框是 elementui组件

如果你用别的组件库或者直接用alert也可以进行替换。)

下面代码中有关于代码详细的注释,如果你的功能和我的有一定的出入可以适当进行修改

1. 在src/router/index.js文件中编写代码

(请注意:token失效后后端返回的错误码是可设置的,你需要和后端人员沟通一下,确定错误码是什么。)

import { MessageBox } from 'element-ui';

//intervalId 是一个变量,用来存储定时器的 ID。定时器会在每秒钟检查一次用户的登录状态。
let intervalId; 
router.beforeEach((to, from, next) => {
  // 在每次路由跳转之前执行的逻辑
  clearInterval(intervalId); // 清除之前可能存在的定时器
  intervalId = setInterval(() => {
    // 每秒钟检查一次 sessionStorage 中的 token 是否存在
    const tokenStr = window.sessionStorage.getItem('token');
    if (this.code == 1001 && to.path !== '/login') {
      // 如果 token 不存在且当前页面不是登录页,则执行以下逻辑
      clearInterval(intervalId); // 清除定时器,避免重复执行弹框逻辑
      MessageBox.confirm('登录已过期,请重新登录。点击确认跳转到登录页面。', '提示', {
        confirmButtonText: '确认',
        type: 'warning'
      }).then(() => {
        // 用户点击确认后跳转到登录页面
        next('/login');
      });
    }
  }, 1000); // 每秒检查一次
  // 继续路由导航
  next();
});

如果你不需要取消按键:

就在MessageBox.confirm里面加上showCancelButton: false

如果你不需要叉号:

加showClose:false

Vue 2中,当用户登录成功获取到JWT(JSON Web Token)后,通常会将其存储在浏览器的localStorage或者Vuex状态管理中。为了实现在token过期自动退出登录回到之前的操作页面,你可以遵循以下步骤: 1. **监听Token变化**: - 在Vuex中,创建一个getter来检查token的有效性,如`isTokenValid`。当token从服务器端更新或本地刷新时,检查新token是否有效。 ```javascript // store.js 或者相应的actions.js中 const getters = { isTokenValid(state) { return state.token && !!(state.token.exp && Date.now() < state.token.exp); } }; ``` 2. **设置守卫(Guard)**: - 在Vue Router的全局守卫中(`router.beforeEach`),检测token有效性。如果无效,则清除token重定向到登录页。 ```javascript import { mapGetters } from &#39;vuex&#39;; export default { // 守卫配置 beforeEnter (to, from, next) { const isLoggedIn = mapGetters([&#39;isTokenValid&#39;]); if (!isLoggedIn) { localStorage.removeItem(&#39;token&#39;); router.push(&#39;/login&#39;); // 跳转登录页面 } else { next(); } }, }; ``` 3. **登录功能**: - 用户点击登录按钮后,向服务器发送请求,登录成功后将新的token存储,更新Vuex状态。 4. **导航守卫**: - 如果你想在用户登出时自动清空token返回原页面,可以添加一个全局的`beforeDestroy`守卫,在组件卸载前清除token。 ```javascript beforeDestroy () { localStorage.removeItem(&#39;token&#39;); } ``` 5. **路由元信息**: - 可以使用Vue Router的`meta`属性,为每个需要权限控制的页面标记上特定的信息,比如`previousPath`,登出后可以根据这个信息跳转回原来的页面。 ```javascript { path: &#39;/protected&#39;, component: ProtectedComponent, meta: { previousPath: window.location.pathname || &#39;/&#39; } } ``` 在登录成功后,访问`this.$route.meta.previousPath`即可回退到之前的页面。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值