shiro 学习之认证详解(一步一步看源码)

本文仅说认证,不说权限,记录下学习认证这块的点点滴滴。

认证过程(一步一步走下去)

首先在源头看,用户调用了login 方法


image.png

调用了 Subject 接口的实现类DelegatingSubject


image.png

调用了 SecurityManager 接口的实现类DefaultSecurityManager


这里 authenticate 方法调用了抽象类AuthenticatingSecurityManager中的authenticate方法

image.png
image.png

不明觉厉,先点进去看看是啥,发现是个接口,有两个实现类,选第一个点进去

image.png

绕了一大圈终于快接近真相了,老样子认证是这句话,接着点下去


image.png

进入了AbstractAuthenticator的抽象类,方法还是没有实现

image.png

调用了ModularRealmAuthenticator的实现吖,因为项目中只配置一个自定义的 realms,所以点进去这个


image.png

调用了当前类的doSingleRealmAuthentication方法,出现了 realm,应该不远了


image.png

因为没配置缓存,所以进入这个方法,看看是怎么拿到 info 的


点进去发现是所有 realm 的实现类,选中我们自己的实现


image.png

原来之前在存入的数据是在这里拿到的啊,当然先判断是否存在这个用户,然后把凭证塞进去返回。


image.png

再回去刚刚那个方法

image.png

现在点进去assertCredentialsMatch()看看是怎么认证的,这是 void 方法,不会返回只会抛异常,所以应该在这里判断返回是 true 还是 false


点进去doCredentialsMatch(),我擦,发现是个接口,发现了这四个实现

  • AllowAllCredentialsMatcher:由名字可以看出是任何info都会返回 true
  • HashedCredentialsMatcher:hash 加密认证
  • PasswordMatcher:这不知道
  • SimpleCredentialsMatcher:基本认证(本例使用这个)

这个类还有四个接口实现,md5,sha1,allowAll,simple,看名字就能知道什么用,我就不多说了。

这个图我 tm 截了有五遍,每次都不会选到SimpleCredentialsMatcher,但是我还要说我选择的就是SimpleCredentialsMatcher,现在点进去

image.png

终于完事了,最终在这里实现了认证,转换成 byte 数组之后进行的比较。


image.png

到此结束

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,643评论 18 399
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,695评论 25 709
  • 不可结缘,亦可相伴 1 太阳刚刚爬过房屋的一角,阳光从地平线散射过来,便随着一股泥土的香味铺面而来,柔和的光线,新...
    四宝日记阅读 3,038评论 2 0
  • 昨天晚上11点15分,2016/17赛季西班牙足球甲级联赛第14轮迎来了一场巅峰对决,巴塞罗那主场迎战皇家马德里,...
    独行侠者阅读 7,744评论 0 2
  • 周末带萌宝去外婆家去玩了会,回来的路上萌宝玩爸爸枪把手指弄疼了,有一点点疼,她那时困了,我横抱着她在怀里,她让...
    胡小花_阅读 1,751评论 0 0

友情链接更多精彩内容