angular基于路由控制ui-router實現(xiàn)系統(tǒng)權(quán)限控制
前端去實現(xiàn)權(quán)限控制聽起來有點扯淡(實際也有點扯淡),掩耳盜鈴,主要是擔心安全問題,但是如果在前后端分離的情況下,需要做一個帶有權(quán)限控制的后臺管理系統(tǒng),angular基于ui-router應(yīng)該怎么做呢?
權(quán)限的設(shè)計中比較常見的就是RBAC基于角色的訪問控制,基本思想是,對系統(tǒng)操作的各種權(quán)限不是直接授予具體的用戶,而是在用戶集合與權(quán)限集合之間建立一個角色集合。每一種角色對應(yīng)一組相應(yīng)的權(quán)限。
一旦用戶被分配了適當?shù)慕巧?,該用戶就擁有此角色的所有操作?quán)限。這樣做的好處是,不必在每次創(chuàng)建用戶時都進行分配權(quán)限的操作,只要分配用戶相應(yīng)的角色即可,而且角色的權(quán)限變更比用戶的權(quán)限變更要少得多,這樣將簡化用戶的權(quán)限管理,減少系統(tǒng)的開銷。
前端基于angular開發(fā)的管理系統(tǒng)在權(quán)限控制方面需要處理如下幾種情況:
1、UI,該用戶對應(yīng)的角色權(quán)限能夠訪問哪些頁面不能訪問哪些頁面;
2、理由,當用戶準備跳轉(zhuǎn)到某一頁面時,如果沒有該頁面的訪問權(quán),重定向到一個錯誤提示頁面;
3、http請求,該用戶是否具有訪問某些API的權(quán)限,如果沒有返回403
如果處理以上問題?
大致思路是:
1、用戶登錄后從server獲取該用戶的permission
2、然后建立一個service來保存該permission的映射關(guān)系,比如a用戶的permission是查看page1,page2,那么在路由發(fā)生變更之前判斷是否有訪問的權(quán)限,有正常跳轉(zhuǎn),沒有則跳轉(zhuǎn)到統(tǒng)一的403頁面或者其他。
3、對于http請求,可以讓server來處理,判斷用戶是否有請求權(quán)限
獲取用戶permission,比如:
var permissionList;
angular.element(document).ready(function() {
$.get('/api/UserPermission', function(data) {
permissionList = data;
angular.bootstrap(document, ['App']);
});
});
這里用到的是jquery的ajax,因為在此之前angular還沒啟動,如果我們的登錄也是用angular實現(xiàn),可以在登錄之后讓server返回permission,然后保存下來。
判斷該用戶是否具有某個權(quán)限,比如:
app.factory('permissions', function($rootScope) {
return {
hasPermission: function(permission) {
if (permission) {
if (typeof(permission) == "string") {
if (permissionList.indexOf(permission) > -1) {
return true;
}
}
}
return false;
}
};
});
路由權(quán)限控制:
app.run(function($rootScope, $location,$state, permissions) {
$rootScope.$on('$stateChangeStart', function(event, toState, toParams, fromState, fromParams) {
var permission = toState.permission;
if (toState.name!="login"&&!permissions.hasPermission(permission)) {
// event.preventDefault();
// $state.transitionTo("login");
}
});
});
//路由配置
app.config(function($stateProvider, $urlRouterProvider, $controllerProvider) {
app.registerController = $controllerProvider.register;
app.loadJs = function(js) {
return function($rootScope, $q) {
var def = $q.defer(),
deps = [];
angular.isArray(js) ? (deps = js) : deps.push(js);
require(deps, function() {
$rootScope.$apply(function() {
def.resolve();
});
});
return def.promise;
};
};
$urlRouterProvider.otherwise('/login');
$stateProvider.state('login', {
url: '/login',
templateUrl: '/assets/console/pages/login.html',
controller: 'loginController',
resolve: {
deps: app.loadJs('./controllers/login')
}
});
$stateProvider.state('index', {
url: '/index',
templateUrl: '/assets/console/pages/home.html',
controller: 'indexController',
resolve: {
deps: app.loadJs('./controllers/index')
},
permission: "super_admin"
});
});
開發(fā)過程中實際會遇到的問題:
1、登錄后如何刷新頁面,因為我們的登錄信息部分是server框架實現(xiàn)的,沒完全分離,所以登錄后登錄信息沒有刷新,可以通過判斷fromState和toState來判斷是否從登錄頁面跳轉(zhuǎn)到指定頁面,然后通過 $window.location.reload();實現(xiàn)頁面的整體刷新。
2、跳轉(zhuǎn)后當前導航的選中狀態(tài)更新,state成功后刷新UI
app.run(['$rootScope', "$state", '$window', '$location', '$log', function($rootScope, $state, $window, $location, $log) {
$rootScope.$on('$stateChangeSuccess',
function(evt, toState, roParams, fromState, fromParams) {
//如果是登錄進來就刷新頁面
setTimeout(function(){
appCommon.initUI();
},500);
});
}]);
相關(guān)文章
AngularJs Injecting Services Into Controllers詳解
本文主要介紹AngularJs Injecting Services Into Controllers的知識,這里整理了一下相關(guān)資料,及示例代碼,幫助大家學習和理解,有興趣的小伙伴可以參考下2016-09-09
詳解創(chuàng)建自定義的Angular Schematics
本文對 Angular Schematics 進行了介紹,并創(chuàng)建了一個用于創(chuàng)建自定義 Component 的 Schematics ,然后在 Angular 項目中以它為模板演練了通過 Schematics 添加自定義的 Component,感興趣的小伙伴們可以參考一下2018-06-06
AngularJS基礎(chǔ) ng-mouseover 指令簡單示例
本文主要介紹AngularJS ng-mouseover 指令,這里幫大家整理了AngularJS 指令的基礎(chǔ)知識,并附代碼示例,有興趣的小伙伴可以參考下2016-08-08
Angular2學習教程之TemplateRef和ViewContainerRef詳解
這篇文章主要給大家介紹了Angular2中TemplateRef和ViewContainerRef的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-05-05
angularjs項目的頁面跳轉(zhuǎn)如何實現(xiàn)(5種方法)
本篇文章主要介紹了詳解angularjs項目的頁面跳轉(zhuǎn)如何實現(xiàn) ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
詳解Angular調(diào)試技巧之報錯404(not found)
本篇文章主要介紹了詳解Angular調(diào)試技巧之報錯404(not found),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01
Angular directive遞歸實現(xiàn)目錄樹結(jié)構(gòu)代碼實例
本篇文章主要介紹了Angular directive遞歸實現(xiàn)目錄樹結(jié)構(gòu)代碼實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05
Angular實踐之將Input與Lifecycle轉(zhuǎn)換成流示例詳解
這篇文章主要為大家介紹了Angular實踐之將Input與Lifecycle轉(zhuǎn)換成流示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02

