欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue 頁(yè)面權(quán)限控制和登陸驗(yàn)證功能的實(shí)例代碼

 更新時(shí)間:2019年06月20日 10:42:59   作者:woai3c  
這篇文章主要介紹了Vue 頁(yè)面權(quán)限控制和登陸驗(yàn)證功能的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

頁(yè)面權(quán)限控制

頁(yè)面權(quán)限控制是什么意思呢?

就是一個(gè)網(wǎng)站有不同的角色,比如管理員和普通用戶,要求不同的角色能訪問的頁(yè)面是不一樣的。如果一個(gè)頁(yè)面,有角色越權(quán)訪問,這時(shí)就得做出限制了。

Vue 動(dòng)態(tài)添加路由及生成菜單 這是我寫過的一篇文章,

通過動(dòng)態(tài)添加路由和菜單來做控制,不能訪問的頁(yè)面不添加到路由表里,這是其中一種辦法。

另一種辦法就是所有的頁(yè)面都在路由表里,只是在訪問的時(shí)候要判斷一下角色權(quán)限。如果有權(quán)限就讓訪問,沒有權(quán)限就拒絕,跳轉(zhuǎn)到 404 頁(yè)面。

思路:

在每一個(gè)路由的 meta 屬性里,將能訪問該路由的角色添加到 roles 里。用戶每次登陸后,將用戶的角色返回。然后在訪問頁(yè)面時(shí),把路由的 meta 屬性和用戶的角色進(jìn)行對(duì)比,如果用戶的角色在路由的 roles 里,那就是能訪問,如果不在就拒絕訪問。

代碼示例:

路由信息

routes: [
 {
  path: '/login',
  name: 'login',
  meta: {
   roles: ['admin', 'user']
  },
  component: () => import('../components/Login.vue')
 },
 {
  path: 'home',
  name: 'home',
  meta: {
   roles: ['admin']
  },
  component: () => import('../views/Home.vue')
 },
]

頁(yè)面控制

// 假設(shè)角色有兩種:admin 和 user
// 這里是從后臺(tái)獲取的用戶角色
const role = 'user'
// 在進(jìn)入一個(gè)頁(yè)面前會(huì)觸發(fā) router.beforeEach 事件
router.beforeEach((to, from, next) => {
 if (to.meta.roles.includes(role)) {
  next()
 } else {
  next({path: '/404'})
 }
})

登陸驗(yàn)證

網(wǎng)站一般只要登陸過一次后,接下來該網(wǎng)站的其他頁(yè)面都是可以直接訪問的,不用再次登陸。

我們可以通過 token 或 cookie 來實(shí)現(xiàn),下面用代碼來展示一下如何用 token 控制登陸驗(yàn)證。

router.beforeEach((to, from, next) => {
 // 如果有token 說明該用戶已登陸
 if (localStorage.getItem('token')) {
  // 在已登陸的情況下訪問登陸頁(yè)會(huì)重定向到首頁(yè)
  if (to.path === '/login') {
   next({path: '/'})
  } else {
   next({path: to.path || '/'})
  }
 } else {
  // 沒有登陸則訪問任何頁(yè)面都重定向到登陸頁(yè)
  if (to.path === '/login') {
   next()
  } else {
   next(`/login?redirect=${to.path}`)
  }
 }
})

上述所有實(shí)現(xiàn),都可以在我的 vue輕量級(jí)后臺(tái)管理系統(tǒng)基礎(chǔ)模板 項(xiàng)目里找到

總結(jié)

以上所述是小編給大家介紹的Vue 頁(yè)面權(quán)限控制和登陸驗(yàn)證功能的實(shí)例代碼,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • Vue3中引入、封裝和使用svg矢量圖的實(shí)現(xiàn)示例

    Vue3中引入、封裝和使用svg矢量圖的實(shí)現(xiàn)示例

    SVG全稱Scalable Vector Graphics,它是網(wǎng)絡(luò)上使用最廣泛的矢量圖格式,在項(xiàng)目開發(fā)過程中,我們經(jīng)常會(huì)用到svg矢量圖,而且我們使用svg以后,頁(yè)面上加載的不再是圖片資源,本文將給大家介紹Vue3中引入、封裝和使用svg矢量圖的實(shí)現(xiàn)示例,需要的朋友可以參考下
    2024-07-07
  • Vue動(dòng)態(tài)樣式綁定實(shí)例詳解

    Vue動(dòng)態(tài)樣式綁定實(shí)例詳解

    眾所周知vue是操作dom元素的,那么如果有元素要?jiǎng)討B(tài)綁定樣式,這種需求,還是要通過改變數(shù)據(jù)來改變視圖的樣式,下面這篇文章主要給大家介紹了關(guān)于Vue動(dòng)態(tài)樣式綁定的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • 解決echarts圖表使用v-show控制圖表顯示不全的問題

    解決echarts圖表使用v-show控制圖表顯示不全的問題

    這篇文章主要介紹了解決echarts圖表使用v-show控制圖表顯示不全的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue cli3 調(diào)用百度翻譯API翻譯頁(yè)面的實(shí)現(xiàn)示例

    vue cli3 調(diào)用百度翻譯API翻譯頁(yè)面的實(shí)現(xiàn)示例

    這篇文章主要介紹了vue cli3 調(diào)用百度翻譯API翻譯頁(yè)面的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • vue使用pdfjs-dist+fabric實(shí)現(xiàn)pdf電子簽章的思路詳解

    vue使用pdfjs-dist+fabric實(shí)現(xiàn)pdf電子簽章的思路詳解

    最近領(lǐng)導(dǎo)提了一個(gè)新需求:仿照e簽寶,實(shí)現(xiàn)pdf電子簽章,本文給大家介紹vue使用pdfjs-dist+fabric實(shí)現(xiàn)pdf電子簽章的思路,感興趣的朋友一起看看吧
    2023-12-12
  • 在vue-cli腳手架中配置一個(gè)vue-router前端路由

    在vue-cli腳手架中配置一個(gè)vue-router前端路由

    這篇文章主要給大家介紹了在vue-cli腳手架中配置一個(gè)vue-router前端路由的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-07-07
  • Vue中使用eslint和editorconfig方式

    Vue中使用eslint和editorconfig方式

    這篇文章主要介紹了Vue中使用eslint和editorconfig方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 測(cè)試平臺(tái)開發(fā)vue組件化重構(gòu)前端代碼

    測(cè)試平臺(tái)開發(fā)vue組件化重構(gòu)前端代碼

    這篇文章主要為大家介紹了測(cè)試平臺(tái)開發(fā)vue組件化重構(gòu)前端代碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Vue 電商后臺(tái)管理項(xiàng)目階段性總結(jié)(推薦)

    Vue 電商后臺(tái)管理項(xiàng)目階段性總結(jié)(推薦)

    這篇文章主要介紹了Vue 電商后臺(tái)管理項(xiàng)目階段性總結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • 在?Vue?中控制表單輸入方法詳解

    在?Vue?中控制表單輸入方法詳解

    這篇文章主要介紹了在?Vue?中控制表單輸入方法詳解的相關(guān)資料,需要的朋友可以參考下
    2023-04-04

最新評(píng)論