vue登录-路由守卫校验token

router.beforeEach((to, from, next) => {
  if (to.meta.title) {
    document.title = to.meta.title
  }
  // 通过url的token来注册
  let token = sessionStorage.getItem('wxtoken') || ''
  // 如果session和query都没有token,需要去授权
  if (token == '' && !to.query.token) {
    // 去授权
    let url =
      process.env.VUE_APP_AUTHORIZEURL +
      escape('http://shuichang.xinglian.info' + to.fullPath)
    // window.location.href = process.env.VUE_APP_AUTHORIZEURL + uri
    window.location.replace(url)
  } else {
    if (token) {
      // 说明已经有了token,可以直接过去了       
      if (to.name === 'deviceinfo' && !to.query.token) {
        window.location.href =
          process.env.VUE_APP_URL + to.fullPath + '&token=' + token
      } else {
        next()
      }
    } else {
      // 说明第一次进来,session中没有token
      token = to.query.token
      if (!token || !/\S/.test(token)) {
        Message({
          message: '用户未注册或未激活(没有token)',
          type: 'error'
        })
      } else {
        // 第一次拿着token进来要做的事情
        let userIdToken = token.slice(
          token.indexOf('.') + 1,
          token.lastIndexOf('.')
        )
        // 拿到userId和roleList
        let data = JSON.parse(Base64.decode(userIdToken))
        let userId = data.sub
        let roleList = data.roleList.split(',')
        let areaId = data.areaId

        sessionStorage.setItem('wxtoken', token, 30 * 60)
        sessionStorage.setItem('userId', userId)
        sessionStorage.setItem('roleList', JSON.stringify(roleList))
        sessionStorage.setItem('areaId', areaId)
        store.dispatch('changeCurRoleList', roleList)
        next()
      }
    }
  }
})
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue-router提供了导航守卫来保护路由的导航。导航守卫可以在跳转或取消导航的过程中进行拦截。导航守卫可以分为全局守卫、路由独享守卫和组件级守卫。 全局守卫是注册在router实例上的,可以使用router.beforeEach方法注册一个全局前置守卫。在每次路由切换之前,全局前置守卫会被触发并接收to、from和next三个参数。可以在全局前置守卫中进行一些权限验证或者其他操作,然后通过调用next方法来进行导航。 路由独享守卫是在定义路由的时候通过beforeEnter属性来注册。路由独享守卫只会对特定的路由生效,可以在路由配置中定义一个beforeEnter函数来进行拦截操作。 组件级守卫是使用vue-router提供的beforeRouteEnter、beforeRouteUpdate和beforeRouteLeave方法来注册。beforeRouteEnter在进入路由前被调用,而beforeRouteUpdate在当前路由复用时被调用,beforeRouteLeave在离开当前路由时被调用。这些守卫可以在组件内部进行定义,并可以在组件内部进行一些操作,比如获取数据或者进行一些清理工作。 总结起来,vue-router的路由守卫提供了全局守卫、路由独享守卫和组件级守卫来保护路由的导航,可以在不同的阶段进行各种操作,确保路由的安全和灵活性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Vue路由守卫(导航守卫)](https://blog.csdn.net/m0_48949881/article/details/122436528)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值