国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 11:18:22
字體:
供稿:網(wǎng)友

頁面權(quán)限控制

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

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

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

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

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

思路:

在每一個路由的 meta 屬性里,將能訪問該路由的角色添加到 roles 里。用戶每次登陸后,將用戶的角色返回。然后在訪問頁面時,把路由的 meta 屬性和用戶的角色進(jìn)行對比,如果用戶的角色在路由的 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') },]

頁面控制

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

登陸驗證

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

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

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

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

總結(jié)

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 和龙市| 兴山县| 博乐市| 乡宁县| 庐江县| 伊宁县| 莒南县| 米脂县| 济阳县| 福海县| 黑龙江省| 长岭县| 虹口区| 密山市| 阿拉善右旗| 泸溪县| 乌拉特前旗| 乌兰察布市| 瓮安县| 商水县| 无极县| 商南县| 奈曼旗| 聊城市| 清镇市| 灵丘县| 永宁县| 平谷区| 库伦旗| 新宾| 湖州市| 扎兰屯市| 拜泉县| 长子县| 鲁山县| 怀柔区| 榆树市| 汝阳县| 玉林市| 深水埗区| 海阳市|