angular基于路由控制ui-router实现系统权限控制


Posted in Javascript onSeptember 27, 2016

前端去实现权限控制听起来有点扯淡(实际也有点扯淡),掩耳盗铃,主要是担心安全问题,但是如果在前后端分离的情况下,需要做一个带有权限控制的后台管理系统,angular基于ui-router应该怎么做呢?

权限的设计中比较常见的就是RBAC基于角色的访问控制,基本思想是,对系统操作的各种权限不是直接授予具体的用户,而是在用户集合与权限集合之间建立一个角色集合。每一种角色对应一组相应的权限。

 一旦用户被分配了适当的角色后,该用户就拥有此角色的所有操作权限。这样做的好处是,不必在每次创建用户时都进行分配权限的操作,只要分配用户相应的角色即可,而且角色的权限变更比用户的权限变更要少得多,这样将简化用户的权限管理,减少系统的开销。

前端基于angular开发的管理系统在权限控制方面需要处理如下几种情况:

1、UI,该用户对应的角色权限能够访问哪些页面不能访问哪些页面;

2、理由,当用户准备跳转到某一页面时,如果没有该页面的访问权,重定向到一个错误提示页面;

3、http请求,该用户是否具有访问某些API的权限,如果没有返回403

如果处理以上问题?

 大致思路是:

1、用户登录后从server获取该用户的permission

2、然后建立一个service来保存该permission的映射关系,比如a用户的permission是查看page1,page2,那么在路由发生变更之前判断是否有访问的权限,有正常跳转,没有则跳转到统一的403页面或者其他。

3、对于http请求,可以让server来处理,判断用户是否有请求权限

获取用户permission,比如:

var permissionList; 
angular.element(document).ready(function() { 
 $.get('/api/UserPermission', function(data) { 
  permissionList = data; 
  angular.bootstrap(document, ['App']); 
 }); 
});

这里用到的是jquery的ajax,因为在此之前angular还没启动,如果我们的登录也是用angular实现,可以在登录之后让server返回permission,然后保存下来。

判断该用户是否具有某个权限,比如:

app.factory('permissions', function($rootScope) {
    return {
      hasPermission: function(permission) {
        if (permission) {
          if (typeof(permission) == "string") {
            if (permissionList.indexOf(permission) > -1) {
              return true;
            }
          }
        }
        return false;
      }
    };
  });

路由权限控制:

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"
    });
  });

开发过程中实际会遇到的问题:

1、登录后如何刷新页面,因为我们的登录信息部分是server框架实现的,没完全分离,所以登录后登录信息没有刷新,可以通过判断fromState和toState来判断是否从登录页面跳转到指定页面,然后通过 $window.location.reload();实现页面的整体刷新。

2、跳转后当前导航的选中状态更新,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);
      });
  }]);
Javascript 相关文章推荐
基于Web标准的UI组件 — 树状菜单(2)
Sep 18 Javascript
JavaScript 编程引入命名空间的方法
Jun 29 Javascript
jquery 打开窗口返回值实现代码
Mar 04 Javascript
jQuery lazyload 的重复加载错误以及修复方法
Nov 19 Javascript
Js判断参数(String,Array,Object)是否为undefined或者值为空
Nov 04 Javascript
js 3秒后跳转页面的实现代码
Mar 10 Javascript
Javascript学习笔记之 对象篇(一) : 对象的使用和属性
Jun 24 Javascript
基于jQuery实现复选框的全选 全不选 反选功能
Nov 24 Javascript
JS+JSP通过img标签调用实现静态页面访问次数统计的方法
Dec 14 Javascript
浅谈关于JS下大批量异步任务按顺序执行解决方案一点思考
Jan 08 Javascript
JavaScript数组去重实现方法小结
Jan 17 Javascript
vue element和nuxt的使用技巧分享
Jan 14 Vue.js
IOS中safari下的select下拉菜单文字过长不换行的解决方法
Sep 26 #Javascript
javascript动画之模拟拖拽效果篇
Sep 26 #Javascript
微信小程序(应用号)简单实例应用及实例详解
Sep 26 #Javascript
微信小程序 框架详解及实例应用
Sep 26 #Javascript
jQuery中JSONP的两种实现方式详解
Sep 26 #Javascript
javascript的函数劫持浅析
Sep 26 #Javascript
JavaScript中this的四个绑定规则总结
Sep 26 #Javascript
You might like
解析PHP中如何将数组变量写入文件
2013/06/06 PHP
PHP文件上传判断file是否己选择上传文件的方法
2014/11/10 PHP
php从字符串创建函数的方法
2015/03/16 PHP
PHP的消息通信机制测试实例
2016/11/10 PHP
PHP面向对象之里氏替换原则简单示例
2018/04/08 PHP
js读取本地excel文档数据的代码
2010/11/11 Javascript
jQuery弹性滑动导航菜单实现思路及代码
2013/05/02 Javascript
解析JavaScript中delete操作符不能删除的对象
2013/12/03 Javascript
jquery使用jquery.zclip插件复制对象的实例教程
2013/12/04 Javascript
JavaScript调试工具汇总
2014/12/23 Javascript
JSON字符串和对象之间的转换详解
2015/05/26 Javascript
贴近用户体验的Jquery日期、时间选择插件
2015/08/19 Javascript
js实现正则匹配中文标点符号的方法
2015/12/23 Javascript
Angularjs中使用指令绑定点击事件的方法
2017/03/30 Javascript
Vue关于数据绑定出错解决办法
2017/05/15 Javascript
JS时间控制实现动态效果的实例讲解
2017/07/31 Javascript
JS基于正则表达式实现的密码强度验证功能示例
2017/09/21 Javascript
Angular入口组件(entry component)与声明式组件的区别详解
2018/04/09 Javascript
浅析node.js的模块加载机制
2018/05/25 Javascript
基python实现多线程网页爬虫
2015/09/06 Python
Python字典及字典基本操作方法详解
2018/01/30 Python
Python远程视频监控程序的实例代码
2019/05/05 Python
Pytorch之扩充tensor的操作
2021/03/04 Python
Sephora丝芙兰马来西亚官方网站:国际化妆品购物
2018/03/15 全球购物
应聘医药代表职位求职信
2013/10/21 职场文书
毕业求职自荐信格式是什么
2013/11/19 职场文书
简历中个人求职的自我评价模板
2013/11/29 职场文书
大学三年的自我评价
2013/12/25 职场文书
单位成立周年感言
2014/01/26 职场文书
上班看电影检讨书
2014/02/12 职场文书
2016年圣诞节寄语(一句话)
2015/12/07 职场文书
如何写好开幕词?
2019/06/24 职场文书
启迪人心的励志语录:脾气永远不要大于本事
2020/01/02 职场文书
Python-OpenCV实现图像缺陷检测的实例
2021/06/11 Python
Pycharm远程调试和MySQL数据库授权问题
2022/03/18 MySQL
Python必备技巧之函数的使用详解
2022/04/04 Python