菜鸟手把手学Shiro之shiro授权流程

一.首先我们从整体去看一下授权流程,然后再根据源码去分析授权流程.如下图:

流程如下:

1、首先调用 Subject.isPermitted*/hasRole*接口,其会委托给 SecurityManager,而SecurityManager 接着会委托给 Authorizer;

2、Authorizer 是真正的授权者,如果我们调用如 isPermitted(“user:view”),其首先会通过PermissionResolver 把字符串转换成相应的 Permission 实例;

3、在进行授权之前,其会调用相应的 Realm 获取 Subject 相应的角色/权限用于匹配传入的角色/权限;

4、Authorizer 会判断 Realm 的角色/权限是否和传入的匹配,如果有多个 Realm,会委托给ModularRealmAuthorizer 进行循环判断,如果匹配如 isPermitted*/hasRole*会返回 true,否则返回 false 表示授权失败。

 二.从开发应用层角度

 1.在controller中的某个方法上使用权限注解@RequiresRoles("role:admin")或者@RequiresPermissions("user:add")等注解,来进行权限控制

或者使用hasRole()方法

 2. 进行授权必须先要进行登录认证,下面对hasRole()进行跟踪,会调用securityManage的hasRole()方法。

 3.继续对securityManager的hasRole()方法跟踪,会进入AuthorizingRealm类中,调用getAuthorizationInfo()方法

 继续跟踪getAuthorizationInfo()方法,这个方法里面首先会对principals做判断,然后再从缓存中去查询,如果再缓存中没有查到info,(我们这里没有没有使用缓存),就继续往下看,然后我们就看到了一个似曾相识的方法doGetAuthorizationInfo(),你没有看错,这个方法我们曾经见过,就是在自定义Realm类的时候里面要重写两个方法,一个是重写授权方法,一个是重写认证方法。

 继续跟踪doGetAuthorizationInfo(),就会选择它的实现类,这里我们选择我们自定义的MyRealm类中,进入到重写方法中

首先根据登录的用户信息,去数据库查询该用户拥有的角色信息,然后把该用户所有的角色信息都放到authorizationInfo对象中,对于权限而言也是这样的,都放到authorizationInfo对象中

 

 

 4. 我们继续返回到AuthorizingRealm类中,刚才在MyRealm中,把用户的角色和权限信息都放在了AuthorizationInfo对象中给返回来了,那么现在进行下一步的hasRole(roleIdentifier,info)

 5. 继续跟踪hasRole()方法,首先会对info做非空的判断,最后再检测传入的roleIdentifier是否包含在info信息中。

 以上就是授权角色的详细过程,对于权限的话自己可以去一步一步跟踪看源码是如何实现的!

 

 

 

posted @ 2019-11-12 15:04  肖恩雷  阅读(554)  评论(0编辑  收藏  举报