使用springSecurity完成快速登录

一、项目需求

这里的项目分为管理端和客户端,要求管理端在客户端用户列表可以一键跳转客户端并且能够免密登录该账户

二、解决思路

1.我们这里的框架是springSecurity,首先想到的是能不能在后台直接走一遍登录的流程,获取到token,再由前端拿着这个token来进行跳转。

故而我们的切入点就是鉴权这一块了,springSecurity 有个 AbstractAuthenticationProcessingFilter 抽象类

(AbstractAuthenticationProcessingFilter 的职责也就非常明确:处理所有HTTP Request和Response对象,并将其封装成AuthenticationMananger可以处理的Authentication。并且在身份验证成功或失败之后将对应的行为转换为HTTP的Response,同时还要处理一些Web特有的资源比如Session和Cookie。)

2.集成之后重写 attemptAuthentication(鉴权并生成Authentication),获取HttpServletRequest中前端传来对应的userId,然后再 new UserAuthentication(),完成该方法

3.但此时是有两个问题的 , 一个是 我们怎么知道是哪个接口应该这么处理 ,第二个就是我们怎么能确定是正常登陆鉴权还是快速登录。

这里跟我们需要用到的几个类起个名字 WebSecurityConfigurerAdapter 的子类 为 类A ,

快速登录获取Authentication 为 类B ,普通登录获取Authentication 为 类C ,类B和类C 继承 接口BC ,继承AbstractAuthenticationProcessingFilter 为 类D

我们可以使用设计模式(具体不清楚,以后学完了可以补),定义一个 接口BC,并在 类D 的attemptAuthentication方法获取Authentication(那我们怎么知道是哪个实现类呢?)

WebSecurityConfigurerAdapter 是 springSecurity 的 配置类 ,我们继承他生成 类A 并重写 configure 方法 ,并在configure 方法 中获取 所有实现 接口BC 的类,遍历他们,将其作为参数扔到 类D 中 ,同时 类D 继承完AbstractAuthenticationProcessingFilter 后的构造方法可以根据路径 进行过滤,这时我们只需要在 接口BC 定义一个获取 登录路径的接口,就完美解决了这个两个问题。

三、总结

我们 在 AbstractAuthenticationProcessingFilter 过滤器中重写鉴权 , 并通过 配置WebSecurityConfigurerAdapter ,指定不同路径做不同的鉴权 ,最后生成 Authentication 。

相关推荐
咕白m6251 小时前
Java 实现 Excel 转 HTML:完整示例
java
RealPluto2 小时前
Spring AOP 失效排查
java·spring
码路飞2 小时前
热榜全是 OpenClaw,但我用 50 行 Python 就造了个桌面 AI Agent 🤖
java·javascript
Nyarlathotep01132 小时前
LinkedList源码分析
java·后端
用户8307196840822 小时前
Java 告别繁琐数据统计代码!MySQL 8 窗口函数真香
java·sql·mysql
带刺的坐椅3 小时前
SolonCode v0.0.20 发布 - 编程智能体(新增子代理和浏览器能力)
java·ai·agent·solon·solon-ai·claude-code·openclaw
会员源码网4 小时前
数字格式化陷阱:如何优雅处理 NumberFormatException
java
孔明click335 小时前
Sa-Token v1.45.0 发布 🚀,正式支持 Spring Boot 4、新增 Jackson3/Snack4 插件适配
java·sa-token·开源·springboot·登录·权限认证
程序猿阿越5 小时前
Kafka4源码(二)创建Topic
java·后端·源码阅读
悟空码字5 小时前
Spring Boot 整合 MongoDB 最佳实践:CRUD、分页、事务、索引全覆盖
java·spring boot·后端