SpringSecurity源码解析(二)

SpringSecurity是如何完成登录过后接口完成用户信息验证的?

首先在我们登录过后,服务器会给在session中存入用户的相关信息。不清楚的可以看我上一篇文章SpringSecurity源码解析(一)
这里我们讲一下,用户在登录过后,是如何拿着sessionId就完成访问的。

  1. SecurityContextPersistenceFilter,在上一篇文章中,我们看到的第一张图中的拦截器链中有这么一个拦截器。这个类是用来干什么的。就是用来处理我们已经登录过的请求。
    在这里插入图片描述

  2. 我们来详细的看一下上图中的第二个方法。
    在这里插入图片描述

  3. 这里我们看一下req里面存的用户信息
    在这里插入图片描述

  4. 这里我们进入到这个readSecurityContextFromSession的方法里面看一下。这里就是拿到已经存着的用户信息。

在这里插入图片描述

  1. 至此。所有的验证拿用户信息的操作,已经全部完成。接下来给大家补充点内容,还是刚才的那个方法。我们看他的finally里面的内容。可以看到,在所有的拦截器完成之后,他会把存到securityContextHolder中的用户信息。进行一个清除的操作。
    在这里插入图片描述

小节:这两篇文章适合稍微看过这个框架讲解的同学。如果不清楚框架的一些基本内容,还是稍微有点头大。不过这个可以基本概括一下中心思路就是
用户登录传入账号和密码,security进行封装,然后框架根据用户名在数据库里面查到用户信息。然后通过数据库查出的用户信息和登录传过来的密码的比对,如果相同。则把用户信息存入session中,再接下来的访问中,通过session中拿到用户信息,进行畅通无阻的访问。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值