shiro中AuthorizingRealm接口的doGetAuthorizationInfo 与doGetAuthenticationInfo什么时候调用

这两个方法虽然名字很像,但是意义是不一样的,doGetAuthorizationInfo方法是进行权限验证,doGetAuthenticationInfo是进行身份验证的(登录验证),相信很多初学者对于这两个方法的调用时机可能不太明白,今天楼主搞了一下午的测试大致明白这两个方法的调用时机。

1.doGetAuthorizationInfo方法

    该方法主要是用于当前登录用户授权(作者小白插一句:我实现该方法时只是进行了当前登录用户的角色与权限初始化,至于授权判断估计shiro帮我们做了)

    1.调用SecurityUtils.getSubject().isPermitted(String str)方法时会调用doGetAuthorizationInfo方法,SecurityUtils.getSubject().isPermitted(String str)方法返回的是boolean值所以开发者得自定义业务逻辑。

    2.在配置文件中配置有类似/**=roles["user"]或者/**=perms[“user”](/**路径是开发者自行定义)的配置的时候会调用doGetAuthorizationInfo方法,这个时候有两种情况:

       一、 当当前没有用户登录时shiro会帮我们跳转到login.jsp(默认会找根目录下的login.jsp)

       二、当前有登录用户时shiro会自动判定当前登录用户的角色或者权限符合访问当前访问路径,如果不符合那么将跳转到开  

            发者所配置的未授权提示页面( <property name="unauthorizedUrl" value="/unauthorized.jsp"/>),这种调用情

            下doGetAuthorizationInfo方法只会被调用一次,除非更换了当前登录用户。


2.doGetAuthenticationInfo方法
    该方法是进行用户验证的

    1.调用currUser.login(token)方法时会调用doGetAuthenticationInfo方法,作者小白重写该方法的主要内容是根据提交的用户名与密码到数据库进行匹配,如果匹配到了就返回一个AuthenticationInfo对象否则返回null,同样shiro会帮我们进行判断当返回null的时候会抛出一个异常,开发者可根据该异常进行相应的逻辑处理


作者小白也是shiro的初学习者,写该文章的主要目的也是想跟大家共同学习,共同进步,该文章有什么不足的地方还请大家多多指出,活到老,学到老。




  • 13
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Shiro ,当进行身份认证(Authentication)和授权(Authorization)操作时,框架会在适当的时机调用自定义的 `AuthorizingRealm` 类的方法。 具体来说,以下是 `AuthorizingRealm` 类的一些重要方法: 1. `doGetAuthenticationInfo(AuthenticationToken token)`: 在身份认证过程调用。该方法用于根据传入的认证令牌(`AuthenticationToken`)获取用户的身份信息(如用户名、密码等),并返回一个 `AuthenticationInfo` 对象,表示用户的认证信息。 2. `doGetAuthorizationInfo(PrincipalCollection principals)`: 在授权过程调用。该方法用于根据传入的主体集合(`PrincipalCollection`)获取用户的授权信息(如角色、权限等),并返回一个 `AuthorizationInfo` 对象,表示用户的授权信息。 当 Shiro 需要进行身份认证或授权时,它会根据配置的 Realm 来选择对应的 `AuthorizingRealm` 实例,并调用相应的方法来获取认证信息或授权信息。 在调用过程Shiro 会根据传入的参数和配置的 Realm,自动触发相应的方法调用。这些方法会在适当的时机被调用,以完成身份认证和授权操作。 需要注意的是,`AuthorizingRealm` 类是一个抽象类,需要自定义实现并注册到 Shiro 的配置。通过自定义 `AuthorizingRealm` 类,你可以根据业务需求来实现身份认证和授权的逻辑,以便 Shiro 在需要时调用相应的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值