我正在开发一个平均堆栈 Web 应用程序,其中包含基于登录用户角色的差异访问。几乎没有不同的角色,例如管理员、政府、志愿者等。
1.如何根据角色管理前端?
目前我正在为每个角色设置全局标志,例如 isAdmin、isVolunteer、isGovt 等,并根据它们的值,我可以使用显示不同的 UIdata-ng-if = "Global.isAdmin"
这种做法是否正确。如果不是,请建议处理 UI 的正确方法。
2. 如果用户没有授权,如何管理后端和重定向路由?
目前我正在尝试使用angular-permission和rbac但仍然无法在我的应用程序中成功使用它们。谁能告诉我平均堆栈网络应用程序基于角色的访问控制的最佳实践。
在尝试使用angular-permission时,我无法将创建的角色链接到路由文件。
这是角色模块。
angular.module('mean.users', ['permission'])
.run(['permission', 'Global', '$q',
function(Permission, Global, $q) {
console.log('not anonumous');
Permission
.defineRole('anonymous', function(stateParams) {
var deferred = $q.defer();
if (Global.user) {
deferred.resolve();
} else {
deferred.reject();
}
return deferred.promise;
})
.defineRole('admin', function(stateParams) {
if (Global.isAdmin) {
deferred.resolve();
} else {
deferred.reject();
}
return deferred.promise;
})
.defineRole('govt', function(stateParams) {
if (Global.isGovt) {
deferred.resolve();
} else {
deferred.reject();
}
return deferred.promise;
})
.defineRole('volunteer', function(stateParams) {
if (Global.isVolunteer) {
deferred.resolve();
} else {
deferred.reject();
}
return deferred.promise;
});
}
]);
如何在路由文件中链接上面配置的角色
$stateProvider
.state('create user', {
url: '/users/create',
templateUrl: 'users/views/create.html',
resolve: {
loggedin: checkLoggedin
}
})
.state('all users', {
url: '/users/list',
templateUrl: 'users/views/list.html',
data: {
permissions: {
only: ['admin'],
redirectTo: 'home'
}
}
})
.state('show user', {
url: '/users/:userId/view',
templateUrl: 'users/views/view.html',
resolve: {
loggedin: checkLoggedin
}
})
.state('edit user', {
url: '/users/:userId/edit',
templateUrl: 'users/views/edit.html',
data: {
permissions: {
only: ['admin']
}
}
})
.state('myprofile', {
url: '/users/:userId/me',
templateUrl: 'users/views/myprofile.html',
resolve: {
loggedin: checkLoggedin
}
});