vue路由跳转时判断用户是否登录功能的实现

网友投稿 306 2023-03-23


vue路由跳转时判断用户是否登录功能的实现

通过判断该用户是否登录过,如果没有登录则跳转到login登录路由,如果登录则正常跳转。

一丶首先在用户登录前后分别给出一个状态来标识此用户是否登录(建议用vuex);

简单用vuex表示一下,不会可以自己去官网多看看;

import Vue from ‘vue‘

import Vuex from ‘vuex‘

Vue.use(Vuex);

var state = {

isLohttp://gin:0, //初始时候给一个 isLogin=0 表示用户未登录

};

const mutations = {

changeLogin(state,data){

state.isLogin = data;

}

};

二丶在用户登录时改变登录状态;

this.$store.commit(‘changeLogin‘,‘100‘)

//登录后改变登录状态 isLogin = 100 ;

三丶重点来了;

在你的路由入口加上导航钩子,具体什么意思看代码;

一丶设置需要校验的路由

{ path: ‘/admin‘,

component: Admin,

meta:{auth:true} // 设置当前路由需要校验 不需要校验的路由就不用写了;TYEMccV不要问为什么,自己去看官网

}

二丶路由跳转并校验

router.beforeEach((to,from,next) => {

if(to.matched.some( m => m.meta.auth)){

// 对路由进行验证

if(store.state.isLogin==‘100‘) { // 已经登陆

next() // 正常跳转到你设置好的页面

}

else{

// 未登录则跳转到登陆界面,query:{ Rurl: to.fullPath}表示把当前路由信息传递过去方便登录后跳转回来;

       next({path:‘/login‘,query:{ Rurl: to.fullPath} })

     }

    }else{

      next()

  }

})


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:浅谈Spring bean 生命周期验证
下一篇:Java实现产生随机字符串主键的UUID工具类
相关文章

 发表评论

暂时没有评论,来抢沙发吧~