解决用户未登陆,输入IP地址仍能访问静态页面的问题

解决办法就是,判断用户的登陆状态,如果没有登陆,将路由强制转换到登陆页,在router/index.js的登陆路由配置中写入

 routes: [{
      path: '/',
      name: 'LoginIn',
      component: resolve => require(['../pages/login/Login.vue'], resolve)
    },
    {
      path: '/home',
      name: 'Home',
      component: resolve => require(['../components/Home.vue'], resolve),
      meta: {
        requireLogin: true // 当前路由需要校验,不需要就不用写
      },

meta:{

requiredLogin:true

}

在入口main.js内写入

router.beforeEach((to,form,next)=>{
  if(to.matched.some(record=>record.meta.requireLogin)){  //判断该路由是否需要登录权限
    if(getCookieValue("userInfo")){
      next();
    }else{
      next({
        path:'/'
      })
    }
  }else{
    next();
  }

router.beforeEach钩子函数在路由跳转之前判断,参数:to:即将跳转的下一个路由,from:即将离开的上一个路由,next,要去的路由。next是必须的,否则不知道下一步干什么。我getCookieValuez自定义获取cookie函数,如果能拿到userInfo且不为空(已登录成功),则继续执行,如果拿不到,返回Loginin路由(登陆页面)。

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值