shiro系列2-权限管理解决方案

什么是粗粒度和细粒度权限

  • 粗颗粒度权限管理,是对资源类型的权限管理。
    资源类型比如:菜单、url链接、用户添加页面、页面信息、类方法、页面中按钮…
    粗粒度权限管理比如:超级管理员可以访问户添加页面、用户信息等全部页面。
    部门管理员可以访问用户信息页面包括 页面中所有按钮。

  • 细颗粒度权限管理,是对资源实例的权限管理。
    比如,员工号为001的修改链接,研发中心的用户信息,研发中心的员工…
    说的简单点,细粒度的权限管理,就是数据级别的权限管理。
    细粒度权限管理比如:部门经理只可以访问本部门的员工信息,用户只可以看到自己的菜单,大区经理只能查看本辖区的销售订单。

如何实现粗粒度和细粒度权限

粗颗粒度权限管理

粗粒度权限管理比较容易将权限管理的代码抽取出来在系统架构级别统一处理。比如:通过springmvc的拦截器实现授权。

细颗粒度权限管理

对细粒度权限管理在数据级别是没有共性可言,针对细粒度权限管理就是系统业务逻辑的一部分,如果在业务层去处理相对比较简单,就在service层处理的时候,传个部门id进去进行判断。如果将细粒度权限管理统一在系统架构级别去抽取,比较困难,即使抽取的功能可能也存在扩展不强。
建议细粒度的权限控制放在业务层去实现。
比如:部门经理只查询本部门员工信息,在service接口提供一个部门id的参数,controller中根据当前用户的信息得到该用户属于哪个部门,调用service时将部门id传入service,实现该用户只查询本部门的员工。

粗粒度和细粒度例子

系统有一个用户列表查询页面,对用户列表查询分权限,如果粗颗粒管理,张三和李四都有用户列表查询的权限,张三和李四都可以访问用户列表查询。
进一步进行细颗粒管理,张三(行政部)和李四(开发部)只可以查询自己本部门的用户信息。张三只能查看行政部 的用户信息,李四只能查看开发部门的用户信息。
细粒度权限管理就是数据级别的权限管理。

基于url拦截的方式实现

基于url拦截的方式实现在实际开发中比较常用的一种方式。
对于web系统,通过filter过虑器实现url拦截,也可以springmvc的拦截器实现基于url的拦截。

使用权限框架实现

对于粗粒度权限管理,建议使用优秀权限管理框架来实现,节省开发成功,提高开发效率。
shiro就是一个优秀权限管理框架。