删除权限的流程

权限系统的操作流程:

用户和角色之间: 多对多关系
一个用户可以拥有多个角色,
一个角色可以赋给多个用户.

角色和权限之间:多对多关系
一个角色可以拥有多个权限,
一个权限可以赋给多个角色.

权限表达式:ssh.web.action.EmployeeAction:delete从而何来.
自定义一个注解标签:RequiredPermission,用来贴在Action类中需要权限才能访问的方法上.

使用注解:

加载权限操作:
1):扫描BaseAction的所有子类.
2):获取每一个Action类中的所有方法.
3):并判断Action的方法上是否存在RequiredPermission注解,如果存在,获取该注解对象.
4):每次遇见RequiredPermission的方法,都创建出Permission对象,并设置Permission对象中的name和expression.
name属性: 获取RequiredPermission注解的value属性设置.
expression属性:得到当前方法所在类的全限定名:方法名称.
5):调用permissionDAO.save(权限对象);

操作一个功能,如删除员工:
1):登陆系统:
1):把登陆信息存储到session中.
2):查询出当前登陆用户所有的权限表达式,并存储到session中.


2):操作具体的某一个功能.
1):判断当前登陆用户是否是超级管理员,若是直接放行,否则GOTO 2.
2):判断当前请求的Action方法上是否存在,RequiredPermission标签,如果没有(不需要权限),直接放行,否则GOTO 3.
3):获取当前请求Action方法对应的权限表达式:ssh.web.action.EmployeeAction:delete.
4):s.
存在: 直接放行

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,666评论 25 708
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,780评论 18 399
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,974评论 6 342
  • 装饰器的作用: 装饰模式有很多经典的使用场景,例如插入日志、性能测试、事务处理等等,有了装饰器,就可以提取大量函数...
    冰西瓜大郎阅读 229评论 0 0
  • 2017年1月 时间管理课程学习,对时间管理有了新的认知。然后开始了一系列的自我成长的学习。 2017年2月 下...
    李聘2023阅读 268评论 0 0