Vue使用localStorage设置token及过期时间

在这里插入图片描述

login.vue

methods: {
      submitForm(formName) {
        this.$refs[formName].validate((valid) => {
          if (valid) {
            this.$notify({
              title: '登录成功!',
              type: 'success',
              duration: 1000
            });
            // 本地存储token(uid)数据;清除token:localStorage.removeItem('token');
            let paramss = {name: 'token', value: this.ruleForm.username};
            var datas = Object.assign(paramss, { startTime: new Date().getTime() });
            localStorage.setItem("token", JSON.stringify(datas));
            // 延迟1s 跳转页面
            setTimeout(()=>{this.$router.push({name: "index"});},1000)
          } else {
            return false;
          }
        });
      }
    },

main.js

// 设置登录过期时间(一天)
let EXPIRESTIME = 86400000


// 校验登录
router.beforeEach(function(to, from, next) {
  if (to.meta.needLogin) {
    //页面是否登录,本地存储中是否有token(uid)数据,否:跳转登录页面
    let item = localStorage.getItem("token");
    try {
        item = JSON.parse(item);
    } catch (error) {
        // eslint-disable-next-line no-self-assign
        item = item;
    }
    if (item) {
      let date = new Date().getTime();
      // 如果大于就是过期了,如果小于或等于就还没过期
      if (date - item.startTime > EXPIRESTIME) {
          localStorage.removeItem('token');
          next({
            name: "login"
          });
      } else {
        next();
      }
    } else {
      next({
        name: "login"
      });
    }
  } else {
    next();
  }
});

  • 14
    点赞
  • 47
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

i码充电桩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值