• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
老杨随笔-重用与重构的艺术
专注于RIA架构设计,无止境的重构,无限制的重用
博客园    首页    新随笔    联系   管理    订阅  订阅

注解式功能权限控制机制

  1. 权限定义表:  定义一个SysUser.GetAclMap 的方法, 返回的是[{code,name}, {code2,name2} ...] 的json结构。
    在功能权限中, code对应url, 而name则是当前用户是否拥有权限: null 没有; Y 有权限.
  2. 在Controller中配置Authorize注解, 可以在class上定义, 也可以在action中定义
    通过order控件校验顺序
  3. 通过actionKey指定
  4. 权限验证方式:
    1. 验证当前ActionKey是否存在于“权限定义表”    (ContainsKey)
      1. --Yes , 判断权限定义表中, 用户授权值(get): null  (未授权),或者not null (已授权)
      2. -- No,  认定为无需校验项, 返回 (已授权)
    2. 如果Action未定义Authorize注解, 则向上使用Controller上的Authorize注解定义。
    3. Authorize可以定义 order和actionKey, 实现重定向的检测。
       如页面功能:列表页, 编辑页, 保存, 删除。  
          为删除Action设定  一组order{ 保存, 编辑页  } 。 由于首先总是检测当前action, 所以等同于 order={ 删除, 保存, 编辑页  }
      1. 检测权限  “删除” , 若已ContainsKey, 直接返回 授权值。   若未定义, 继续向下执行;
      2. 检测权限 “保存” , 若已ContainsKey,  直接返回 授权值。   若未定义, 继续向下执行;
      3. 检测权限 “编辑页” , 若已ContainsKey,  直接返回 授权值。   若未定义, 继续向下执行;
      4. 认定无需校验, 返回 (已授权)
  5. 若要禁用当前Action的权限检测
    1. 在action上设置 order=-1 且action=""
  6. 最后, 为启用以上功能, 在jfinal 启动时配置:

    public void configInterceptor(Interceptors me) {
              me.addGlobalActionInterceptor(new AuthorityValidateInterceptor());//进行所有Action与权限配置表的匹配检测
              me.addGlobalActionInterceptor(new ControllerInViewInterceptor());//允许FreeMaker访问到session的值
    }

注意: 权限项设置(菜单定义)时, 不得将 /portal/user/index 简写为 /portal/user/ 否则导致权限判断为“无权限”。导致排查困难。

 

posted @ 2017-02-10 14:09  craboYang  阅读(2074)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3