使用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 。

相关推荐
Qt程序员5 分钟前
掌握 Linux 内核调度:从原理到实现(进程篇)
java·开发语言
code bean9 分钟前
【LangChain】检索器完全指南:从向量检索到生产级 RAG 架构
java·开发语言·微服务
大白菜和MySQL11 分钟前
java应用排查高线程
java·python
KobeSacre24 分钟前
ReentrantLock源码
java
嵌入式协会202407229 分钟前
(已解决)MinIO python 获取预签名出现forbidden、errornetwork等错误
java·开发语言·python
不才不才不不才1 小时前
Spring AI 实战:聊天、提示词、记忆三件套
java·人工智能·spring·ai
一 乐2 小时前
家政服务管理系统|基于springboot + vue家政服务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·家政服务管理系统
碳基硅坊4 小时前
Spring AI:把大模型接进 Spring 应用
java·人工智能·spring ai
黄毛火烧雪下4 小时前
Java 核心知识点总结(一)
java·开发语言
技术小结-李爽4 小时前
【工具】Maven的下载、安装、使用
java·maven