vue使用路由守卫实现用户登录验证

文章介绍了如何利用Vue的路由守卫功能和token机制来实现用户登录验证。在用户登录成功后,token被保存在sessionStorage中,后续请求会检查token是否存在,若不存在则重定向至登录页面。
摘要由CSDN通过智能技术生成

简述

如果我们需要实现只有登录才能访问的功能性需求,使用token+路由守卫可以非常简单实现登录验证功能。即通过vue的路由守卫预拦截请求,简单实现用户登录验证的需求。

登录

在登录成功后,将token保存到浏览器里面

    login() {
      this.$refs.loginFormRef.validate(async valid => {
        if (!valid) return
        const { data: res } = await this.$http.post('login', this.loginForm)
        if (res.meta.status !== 200) return this.$message.error('登录失败!')
        this.$message.success('登录成功')
        // 1. 将登录成功之后的 token,保存到客户端的 sessionStorage 中
        //   1.1 项目中出了登录之外的其他API接口,必须在登录之后才能访问
        //   1.2 token 只应在当前网站打开期间生效,所以将 token 保存在 sessionStorage 中
        window.sessionStorage.setItem('token', res.data.token)
        // 2. 通过编程式导航跳转到后台主页,路由地址是 /home
        this.$router.push('/home')
      })

权限判定

拦截请求,判定token是否存在,存在则不拦截,不存在则重定向到登录界面。

router.beforeEach((to,from,next)=>{
  if(to.path==='/login') return next();
  //获取名字为名字为token的token令牌
  const token = window.sessionStorage.getItem('token')
  //不存在则直接跳转到登录界面
  if(!token) return next('/login')
  //否则直接跳转回主页
  next()
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值