随笔 - 154  文章 - 0  评论 - 4  阅读 - 49437

login-spring.security用户密码校验authenticate核心流程

前端过来的密码  解密成字符串

private final AuthenticationManager authenticationManager;  // 接口

UsernamePasswordAuthenticationToken authenticationToken =
new UsernamePasswordAuthenticationToken(principal, password);
Authentication authentication = this.authenticationManager.authenticate(authenticationToken);   // 抽象方法

 实现类ProviderManager啥是注入的?

有配置类

Iterator var8 = this.getProviders().iterator();   遍历配置里的三个 providers

 toTest == UsernamePasswordAuthenticationToken

DaoAuthenticationProvider daoAuthenticationProvider, CasAuthenticationProvider casAuthenticationProvider,   ThirdAuthProvider thirdAuthProvider

provider.supports(toTest)    ??? 3个 有两个有 supports 方法

a.isAssignableFrom(b): 是用来判断子类和父类的关系的,或接口的实现类和接口的关系的 

  isAssignableFrom方法是native方法(底层c或c++),它的作用是用来判断两个类的之间的关联关系,也可以说是一个类是否可以被强制转换为另外一个实例对象

简单理解即 a是b的父类或接口

provider.supports(toTest)   ----- 只有一个符合 DaoAuthenticationProvider 的子类 CustomerDaoAuthenticationProvider 

 

 

result = provider.authenticate(authentication);

 

 

 

 

posted on   daofree  阅读(159)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示