您的位置:首页 > 其它

shiro的工作流程

2018-01-04 13:40 141 查看
1.指定配置文件,配置文件中指定authenticator(认证)类型。初始化生成securityManager,初始化securityManager中的authenticator(认证)和realms(源)。securityManager存储为全局变量。

2.创建或获取subject(用于代表当前用户的实体),线程私有变量,存储于threadlocal上。

3.subject调用login(UsernamePasswordToken)方法,用于模拟用户登录,UsernamePasswordToken代表用户名和密码的抽象。

4.委派给securityManager处理。

5.securityManager委派给初始化时指定的authenticator(认证)处理。

6.authenticator循环realms,调用realm中的doGetAuthenticationInfo(用于身份验证)进行身份认证。可继承realm,

重写doGetAuthenticationInfo方法,在其中编写身份认证的业务逻辑。验证失败需抛异常。

7.若需判断用户的角色或权限,调用subject(代表当前用户的实体)的hasroles等方法。

8.委派给securityManager处理。

9.securityManager委派给Authorizator(授权)处理。

10.Authorizator调用realm的doGetAuthorizationInfo方法获取角色和权限,用于比较。

11.待续。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: