springsecurity工作流程

Spring Security 的工作流程如下:

在这里插入图片描述

1.当用户请求一个受保护的资源时,Spring Security 的过滤器链会拦截该请求。

2.然后 Spring Security 会判断该请求是否认证(authenticated)和授权(authorized)。

  • 认证(Authentication):验证用户身份,判断用户是否能登录系统。Spring Security 支持多种认证方式,如 LDAP、Form 登录等。
  • 授权(Authorization):验证用户是否有权限访问某个资源。Spring Security 基于角色(Role)和权限(Permission)进行授权。

3.如果请求未认证,Spring Security 会将用户重定向到登录页面。用户登录后,Spring Security 会将用户信息存储于 SecurityContext 中。

4.如果请求已认证但未授权,Spring Security 会返回 403 禁止访问响应。

5.如果请求已认证且已授权,过滤链会放行请求,调用链继续正常执行。

6.在过滤链的最后,Spring Security 还有一个 Filter 来清理 SecurityContext。这样可以确保安全地结束会话。

具体流程:

1.用户访问首页,不需要认证,可以正常访问。

2.用户点击登录链接,进入登录页登录。

  • 登录请求被 Spring Security 的 Filters 链拦截。
  • 调用 AuthenticationManager 进行认证,成功后将用户信息存储到 SecurityContext。
  • 重定向到首页。

3.用户访问需要权限的页面,请求被拦截。

  • 检查当前请求是否已认证(从 SecurityContext 获取用户信息)。
  • 如果已认证,检查当前用户是否有访问权限(调用 AccessDecisionManager)。
  • 如果有权限,放行请求,继续调用链。
  • 如果无权限,返回 403 响应。

4.用户退出,清空 SecurityContext。

  • 点击退出链接,Spring Security 清空 SecurityContext。
  • 重定向到首页。
  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值