一:任务

1.任务

  认证处理流程说明

  认证结果如何在多个请求之间共享

  获取认证用户信息

二:认证处理流程处理说明

1.流程图

  这里只是一个登陆到登陆的认证部分的流程图。

  

2.流程解释

  

3.断点跟踪

  页面登录,进入这里。

  通过username与password得到一个UsernamePasswordAuthenticationToken。

  

  看看这个UsernameOasswordAuthenticationToken对象的类图。

  

  这里全是类,然后我们看到父类AbstractAuthenticationToken是Authentication的实现类,

  其中,Authentication是封装了登录信息。

  

  我们,进入这个方法。

  先说明setAuthenticationed(false)的意思:上面的是否已经通过验证,在这里肯定是写false了。

  

  关于super这里,我们可以看看父类的做法:

  

  开始到setDeatils。

  

  再到getAuthenticationManager

  本身不包括认证判断逻辑,作用是管理AuthenticationProvider。当然要将带有验证信息的authRequest带入。

  这里进入ProviderManager.class类中的authticate方法。

  这里有一个for循环,因为登录方式不同。support在验证provider是否支持当前的登录方式。

  

  如上图所说,如果通过验证,然后进入result = provider.authenticate(authentication);,进行真正的校验。

  这个时候,我们使用的provider是DaoAuthenticationProvider。

  下面看DaoAuthenticationProvider放入关系:

  

  其实,验证都在AbstractUserDetailsAuthenticationProvider中。

  其中,retrieveUser在子类中实现。

  

  

  开始预检查:

  

  预检查

  

  然后,进行附加的检查:

  

  具体看附加的检查,这里还是需要到子类中看:

  

  然后,进入后检查

  

  这个后检查,主要是检查是否过期

  

  成功。

  

  现在重新赋值权限,返回Authentication(已认证)。

  

  ===========================

  ===========================

  这个时候,已经return了。返回到最开始UsernamePasswordFileter,这里开始成功或是失败的处理器。

  

三:session共享

1.说明

  这里从AbstractAuthenticationProcessingFilter开始,因为这里有一个成功后的处理方法是successfulAuthentication。

2.流程图

  

3.断点

  

  关于SecurityContextHolder,是将authentication放入线程,然后当前线程的任何方法都可以拿到authentication。

4.最前面的一个过滤器

  这个过滤器以前没有讲过,这个过滤器的作用,请求先经过,然后是响应返回的时候最后一个经过。

  

  这里先检查session是否有security context,如果有,则将其从session中取出放入线程,没有就继续。

  在返回的时候,会再检查线程,如果线程中有security context,如果有则拿出来放入session中。

5.再说明

  不同的请求,就可以从同一个session中拿到相同的用户认证信息。

  拿到后,放入线程中。

  这里就是认证结果在多个请求之间共享。

四:获取认证用户信息

1.说明

  这里的意思是从session中获取。

2.程序

  将程序写在UserController中。

   @GetMapping("/securityContext")
public Object getSecurityContext() {
return SecurityContextHolder.getContext().getAuthentication();
}

3.启动程序,进行访问

  

4.简单的程序

     @GetMapping("/securityContext")
public Object getSecurityContext(Authentication authentication) {
return authentication;
}

  

  

最新文章

  1. IdentityHashMap类:增加相同Key(键)内容的结果
  2. Yii源码阅读笔记(三十)
  3. iOS项目工作空间搭建
  4. Java基础(41):Java中集合中需要注意的几个要点(关于Collection与Map)
  5. FastReport处理空日期
  6. ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'db'
  7. qemu源码架构
  8. grails下的httpclient
  9. 杭电1010Tempter of the Bone
  10. jbpm4.4 demo2
  11. shell中case的用法学习笔记
  12. JavaScript中的设计模式:状态模式
  13. VK CUP2017 ROUND 1
  14. LeetCode重建二叉树系列问题总结
  15. 时间插件datepicker(jQuery-UI,bootstrap)和jquery-steps的冲突解决。。。
  16. qt之窗口换肤
  17. 从容器里dump java堆实验探索(原创)
  18. BookStrap之模板继承
  19. MVC在母版页设置子页面的css和js引用布局
  20. 实验一 MiniOS

热门文章

  1. Android 设备的CPU类型(通常称为”ABIs”)
  2. android中的LaunchMode详解----四种加载模式
  3. JS知识点随笔
  4. Confluence 6 数据库表-杂项(Miscellaneous)
  5. Spark Streaming通过JDBC操作数据库
  6. webpack2配置备份
  7. poj2817状态压缩 升维
  8. vue 中动态绑定class 和 style的方法
  9. linux下的抓包
  10. mysql 去除重复 Select中DISTINCT关键字的用法 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是 distinct只能返回它的目标字段,而无法返回其它字段,这个问题让我困扰了很久,用distinct不能解决的话,