Spring Security运行流程的简单理解

Spring Security本质上是一个过滤器链,里面包含着多个过滤器,用来拦截过滤对应的请求

Spring Security 主要分为认证和授权两个部分,认证:用通俗的话来说就是去查看数据库中有没有这个用户;授权:再找到这个用户后对该用户进行权限的赋予。

Spring Security的整个流程大致如下:

1. 首先是用户登录,获取用户名和密码;

2.用户名和密码会被Spring Security拦截:在此过程中,会先获取用户名,然后去比对用户名和数据库中的是否一致,接着通过用户名去查询密码,并比对密码与输入的密码是否一致,其中密码默认通过BCryptPasswordEncoder进行加密;

3.在确认完用户的信息之后,会把用户信息封装到springSecurity LoginUser对象中,如果认证成功,则会通过用户的id查询数据库,获取用户的权限关系;

4.在认证成功之后吗,会将用户对象通过jwt加密,此过程中可以将token顺便放到redis中

5.最后返回给前端的则是token的uuid

在整个过程中,过滤器主要用来判断请求头上有没有token的uuid,如果没有就直接return,如果有的话则通过token的uuid去查看redis中的token;之后对token进行解析,获取body那部分信息;最后通过session进行数据共享,将用户对象信息放到Spring Security的一个本地线程SecContextHolder当中。

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Security流程主要包括认证和授权两个部分。在请求到来时,Spring Security会调用层层过滤器来完成认证。其中,核心的拦截器有登录验证拦截器AuthenticationProcessingFilter和资源管理拦截器AbstractSecurityInterceptor。这些拦截器的实现需要一些组件来支持,例如认证管理器AuthenticationManager和决策管理器accessDecisionManager等。FilterChainProxy是一个代理,真正起作用的是各个Filter,这些Filter被Spring管理,并且各自承担不同的职责,但不直接处理认证和授权,而是交由认证管理器和决策管理器来处理。认证部分主要是查看数据库中是否存在该用户,而授权部分则对该用户进行权限的赋予。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [springsecurity原理流程图.pdf](https://download.csdn.net/download/qq_42468130/11699361)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [SpringSecurity执行流程(笔记)](https://blog.csdn.net/weixin_51542566/article/details/119705963)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Spring Security运行流程简单理解](https://blog.csdn.net/weixin_70312788/article/details/126147105)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值