vue中使用router全局守衛實現頁面攔截


一、背景

  在vue項目中使用vue-router做頁面跳轉時,路由的方式有兩種,一種是靜態路由,另一種是動態路由。而要實現對路由的控制需要使用vuex和router全局守衛進行判斷攔截(安全問題文章最后討論)

二、使用場景

  靜態路由的使用場景:在我們使用靜態路由實現頁面跳轉時,不管我們是否登錄,當我們在地址欄修改地址后,頁面會發生跳轉並展示頁面內容(數據並不會被展示出來),這樣的問題顯然是不能夠被接受的;

  動態路由的使用場景:動態路由無非就是從后端拿到了數據然后在加到router里面了。假如用戶登錄了,在地址欄修改地址便能直接訪問。所以動態路由並不能起到攔截作用。

三、解決方案

  使用vuex+router.beforeEach()+動態路由實現頁面攔截

    頁面刷新時會清楚vuex里面的值;(防止直接修改地址欄)

    router.beforeEach()對跳轉前進行攔截判斷;(對vuex里面的值進行判斷)

    當用戶登錄時請求后台拿到數據,加載路由.(跳轉頁面)

四、實現過程

  1.首先定義vuex里面的值,需要定義兩個值:a.登錄狀態信息的值 loginInfo b.存儲動態路由的值 routerList

  

  2.router.beforeEach()對路由跳轉前進行控制 

//全局守衛
router.beforeEach((to, from, next)=> {
  let userId = store.state.loginInfo.id;
  //這里是對登錄后的值進行判斷,也可對token的值進行判斷
    if (userId === '') {
      if (to.meta.requireAuth || to.name == null) {
        next({path: '/'})
      } else {
        next();
      }
    } else {
      //初始化動態路由方法
      initRouter(router, store); 
      next();
    }
  }
);

3.初始化動態路由

在全局守衛對應條件下加載動態路由數據routerList和在登錄成功時存儲登錄成功的信息loginInfo 

  新建一個xxx.js文件 引入axios 創建一個函數並使用export 暴露該方法;

 請求成功拿到數據后,把數據造成和routes里的數據一樣。然后使用 router.addRoutes 添加進去;

index中的默認路由

 

import axios from 'axios'
export const initRouter = (router,store)=>{
  if (store.state.routerList.length > 0) {
    return;
  }
  axios.get(' URL')
     .then((rest)=>{
      let routerList = [];
      if(rest.data.success){
        let routers = rest.data.body;
        routers.forEach(router=>{
            let {
              path,
              component,
              name,
            } = router
            let routerObj = {
              path:path,
              name:name,
              component(resolve){
                if (component.startsWith("index")) {
                  require(['../components/' + component + '.vue'], resolve)
                }       
                
              },
              meta:{requireAuth:true} //是否是登錄權限控制
            };
            routerList.push(routerObj);
          });
        //add到router中
        router.addRoutes(routerList); 
        //存儲到vuex中
        store.commit('routerList', routerList); 

      }else{
         console.log(rest.data.error);
      }
   }).catch((error)=>{
       console.log(error);
   })
}    
View Code

4.登錄成功后存儲成功狀態信息並跳轉頁面

 

 至此,頁面攔截功能已實現。

五、總結

  該方法實現主要用到了:

  1.vuex及頁面刷新時會對vuex進行清空,所以比如退出時要對頁面window.location.reload(),其它地方類似。

  2.router.beforeEach()鈎子函數及關鍵的router.addRoutes方法

  3.es6的一些寫法

 

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM