Spring Security 的工作流程如下:
1.当用户请求一个受保护的资源时,Spring Security 的过滤器链会拦截该请求。
2.然后 Spring Security 会判断该请求是否认证(authenticated)和授权(authorized)。
3.如果请求未认证,Spring Security 会将用户重定向到登录页面。用户登录后,Spring Security 会将用户信息存储于 SecurityContext 中。
4.如果请求已认证但未授权,Spring Security 会返回 403 禁止访问响应。
5.如果请求已认证且已授权,过滤链会放行请求,调用链继续正常执行。
6.在过滤链的最后,Spring Security 还有一个 Filter 来清理 SecurityContext。这样可以确保安全地结束会话。
具体流程:
1.用户访问首页,不需要认证,可以正常访问。
2.用户点击登录链接,进入登录页登录。
3.用户访问需要权限的页面,请求被拦截。
4.用户退出,清空 SecurityContext。