vue路由-全局前置守卫

本文介绍了如何在VueRouter中配置全局前置守卫,用于在访问支付页和订单页等需要登录的页面时,对未登录用户进行拦截并跳转至登录页面。通过在`beforeEach`钩子中检查token存在性实现权限控制。
摘要由CSDN通过智能技术生成

1. 介绍

详见:全局前置守卫网址

使用场景:

  • 对于支付页,订单页等,必须是登录的用户才能访问的,游客不能进入该页面,需要做拦截处理,跳转到登录页面

全局前置守卫的原理:

全局前置守卫是一种路由守卫,它在路由被访问之前进行拦截。它允许我们在路由被访问之前进行一些处理,例如权限验证、请求参数预处理等。在Vue Router中,我们可以通过在路由配置中添加beforeEnter守卫来实现全局前置守卫。

  • 如图:
    在这里插入图片描述

2. 配置全局前置守卫规则

在 src/router/index.js 文件夹中 添加配置:

// 创建一个数组用来存放,需要用户登录的页面路径
const authUrl = ['/pay', '/myorder']
// 创建全局前置守卫
router.beforeEach((to, from, next) => {
  // 判断是否为权限页面
  if (!authUrl.includes(to.path)) { // 非权限页面直接放行
    next()
  } else {
    const token = store.getters.token
    // console.log(token)
    if (token) {
      next()
    } else {
      next('/login')
    }
  }
})

注:

  1. to 往哪里去, 到哪去的路由信息对象
  2. from 从哪里来, 从哪来的路由信息对象
  3. next() 是否放行
  4. 如果next()调用,就是放行
  5. next(路径) 拦截到某个路径页面

完整代码:

import Vue from 'vue'
import VueRouter from 'vue-router'

import Home from '@/views/layout/home'
import User from '@/views/layout/user'
import Cart from '@/views/layout/cart'
import Category from '@/views/layout/category'

import store from '@/store'

const Login = () => import('@/views/login')
const Layout = () => import('@/views/layout')
const Search = () => import('@/views/search')
const SearchList = () => import('@/views/search/list')
const ProDetail = () => import('@/views/prodetail')
const Pay = () => import('@/views/pay')
const MyOrder = () => import('@/views/myorder')

Vue.use(VueRouter)

const router = new VueRouter({
  routes: [
    {
      path: '/',
      component: Layout,
      redirect: '/home',
      children: [
        {
          path: '/home',
          component: Home
        },
        {
          path: '/user',
          component: User
        },
        {
          path: '/cart',
          component: Cart
        },
        {
          path: '/category',
          component: Category
        }
      ]
    },
    {
      path: '/login',
      component: Login
    },
    {
      path: '/search',
      component: Search
    },
    {
      path: '/searchlist',
      component: SearchList
    },
    {
      path: '/prodetail/:id',
      component: ProDetail
    },
    {
      path: '/pay',
      component: Pay
    },
    {
      path: '/myorder',
      component: MyOrder
    }

  ]
})

// 创建一个数组用来存放,需要用户登录的页面路径
const authUrl = ['/pay', '/myorder']
// 创建全局前置守卫
router.beforeEach((to, from, next) => {
  // 判断是否为权限页面
  if (!authUrl.includes(to.path)) { // 非权限页面直接放行
    next()
  } else {
    const token = store.getters.token
    // console.log(token)
    if (token) {
      next()
    } else {
      next('/login')
    }
  }
})

export default router

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值