精品专区-精品自拍9-精品自拍三级乱伦-精品自拍视频-精品自拍视频曝光-精品自拍小视频

網站建設資訊

NEWS

網站建設資訊

vue后臺管理系統權限控制的示例分析

這篇文章主要介紹vue后臺管理系統權限控制的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

公司主營業務:成都網站設計、網站制作、移動網站開發等業務。幫助企業客戶真正實現互聯網宣傳,提高企業的競爭能力。創新互聯建站是一支青春激揚、勤奮敬業、活力青春激揚、勤奮敬業、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰,讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創新互聯建站推出修武免費做網站回饋大家。

權限控制需求

因為是單頁面應用,路由交給前端來控制,對于一些需要特定權限才能查看的信息的保護變得尤為重要,如果前端不做好權限校驗,后端也一時疏忽,就可能就會導致數據泄露。

對于權限控制,需求大致為如下:

  1. 對于大模塊的限制,比如需要通過路由跳轉的模塊,這時需要進行路由攔截

  2. 對于小功能的限制,比如一個按鈕,如果沒有特定權限,那么這個按鈕就不顯示

安全層面的思考

之前接手了一個管理系統,前端是將權限列表存儲在storage中來實現長久儲存,這種實現方式是很不可取的,因為hacker可以通過手動更改存儲的信息來實現獲取特定權限,甚至系統都沒有做路由攔截,如果知道模塊的路由,可以直接通過輸入路由信息來直接跳轉到特定模塊。對于一些模塊的權限,權限被管理員修改后也無法立即生效,所以對于這幾種情況做了如下思考與實踐。

權限被管理員修改后立即生效

對于這個需求,我的做法是,獲取到權限列表后,將權限信息存儲在 vuex store 中,并且使用getter函數,對于是否可以使用該權限進行判斷,這樣一旦權限數據更新,前端權限限制功能點會自動修改,從而做到權限的實時性,大致實現如下:

// vuex state.js
export default {
  userPrivileges: {
    admin: [],
    purchaser: []
  }, // 用戶權限信息
}
// vuex getters.js
export default {
  canIUse: state => (role, id) => state.userPrivileges[role].includes(id)
}

// 頁面具體小功能,通過 mapGetters 引入 canIUse 函數
{{scope.row.allocation_subtotal}}

這樣一來,數據存儲在內存中,那么權限信息就無法輕易的被修改,同時對于權限的判斷也非常簡單,只需要在特定功能點傳入功能點的權限id就能判斷是否可以使用這個權限了。

但是將數據存儲在了內存中也會遇到一個問題,頁面刷新怎么辦?接下來就是講解這種情況。

刷新頁面也可以進行權限判斷

對于大模塊的權限攔截,肯定是通過路由鉤子來進行攔截的(這種實現有很多文章講解過,這里不具體講解),但是通過路由鉤子進行攔截的前提是,權限信息得提前存在。

刷新頁面會存在這種情況,頁面刷新時,先執行的路由鉤子,再執行的組件生命周期鉤子來請求權限的列表,此時權限信息不存在,那么頁面跳轉到登陸頁的話,體驗就不夠友好。

所以我的做法是,建立一個中間頁,如果權限校驗不通過,那么跳轉至中間頁,中間頁進行權限的請求,請求到權限后,再判斷是否可以跳轉,這樣的話,刷新頁面體驗就比較好。大致代碼如下:

// vuex actions.js
// 通過返回一個promise,使得store更新與后續代碼變為“同步”執行
export default {
  getUserPrivileges({ commit }) {
    return fetch.get({
      url: '/currentstaff'
    }).then(data => {
      commit('SET_USER_PRIVILEGES_INFO', data.data)
      return data.data
    }).catch(e => {

    })
  }
}
// router.js
// 需要驗證權限的路由
{
  path: 'suppliers',
  component: Suppliers,
  meta: {
    role: 'admin',
    privilegeId: 5
  }
}

function isCanUseThisModule(to, from) {
  return to.matched.every(record => {
    // 利用路由meta存儲相應權限信息
    if (record.meta.role) {
      return store.getters.canIUse(record.meta.role, record.meta.privilegeId)
    } else {
      return true // 如果不需要權限,直接返回true
    }
  })
}

router.beforeEach((to, from, next) => {
  if (isCanUseThisModule(to, from)) {
    next() // 權限驗證通過,跳轉下一路由
  } else {
    next({
      path: '/main/privilegeValidator' // 權限驗證不通過時的中間頁
    })
  }
})

// 權限校驗中間頁代碼示例
created() {
  this.$store.dispatch('getUserPrivileges').then(data => {
    for (let i = 0; i < data.admin_permissions.length; i++) {
      if (this.canIUse('admin', data.admin_permissions[i])) {
        this.$router.push({
          path: this.routerList.find(value => value.privilegeId === data.admin_permissions[i]).linkHref
        })
        return
      }
    }
    this.$router.push('/login') // 如果沒有任何權限,則跳轉登陸頁面
  })
}

用戶在登陸后也可以跳轉到這個權限中間頁,進行權限判斷后再跳轉到對應模塊。

以上是“vue后臺管理系統權限控制的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!


分享題目:vue后臺管理系統權限控制的示例分析
新聞來源:http://m.jcarcd.cn/article/goedij.html
主站蜘蛛池模板: 国产全黄三级播放 | 国产一区二区在线播 | 日韩字幕欧美 | 区二区导航 | 区芒果视频 | 9久热草极品 | 理论精品电影 | 日本免费一区二区 | 日韩免费影院 | 国产人妖的免 | 精品热亚洲一级 | 国产末成年呦交在线 | 国产一区二区三区a | 精品综合精品自拍 | 日本在线播放一区 | 午夜福利电影 | 精品欧美一区二 | 日韩男女做性高清在 | 91秦先生久 | 精品日本亚洲18 | 91国精品| 国内老司机精品视频 | 日韩爽歪歪免费视频 | 欧美专区日韩高清 | 精品国精品国产自在 | 中文字幕久热精品 | 国产视频福利导航 | 国产精品玖玖视频 | 日本一区二区在 | 国产精品自产拍高 | 国产精品秘一区二区 | 日本高清不卡视频 | 成人三级网站精品 | 日韩欧美午夜大片 | 国产自产中文一区 | 国偷自产婷婷 | 欧美日韩亚洲国 | 欧美一块操 | 国产人成精品 | 中文字幕亚洲第一 | 国产午夜视频在线 |