SpringSecurity 3.0.2.2版本
前言:
实践,认知,再实践,再认知
回顾:
随着2.0,2.1的实践,我们找到了真正的需求
将默认用户改为自定义用户,而不是读取表单
正片:
随着官方文档的不断阅读,不断阅读,不断阅读,终于——找到了一篇和自定义用户相关的文档
其中有一句,指明了该如何实践
《你可以通过暴露一个自定义的 UserDetailsService
作为一个bean来定义自定义认证》
紧跟着就是解释说明
《例如,假设 CustomUserDetailsService
实现了 UserDetailsService
,那么下面的列表将自定义认证。》
好没看懂,看看前面有没有联系
又长,又难,还抽象
UserDetail是由UserDetailService返回——翻译——用户明细是由用户明细业务返回的
后面这句是什么?先从那个Dao开始的单词开始
Dao是一个实现,接口的实现
我并没有看到它实现authentication这个接口,除非它指继承的ABS这个类实现了
重的来说就是
A类继承了B类,B类实现C接口,因为继承的原因——A类实现C接口
没毛病,兄弟们!代码对上了
使用这个DAO的作用是什么?验证账号和密码
看到这个是啥Authentication
authenticManager是一个接口,Authentication authenticate也能说明它是authenticManager的输入
AuthenticationManage是什么?是定义filter如何执行认证的API
找到了它的实现
实例化AuthenticationObservationContext()
调用了该部分的Authorities两个方法
这段代码就是在说如何执行认证,这个执行更多的是指顺序
Authentication是AuthenticationManage的一个输入,是指认证顺序的输入
Authentication的 第二个功能是认证功能,认证三部分,用户,密码,权限
总结下来就是这张图