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

相关推荐
Daniel 大东9 分钟前
idea 解决缓存损坏问题
java·缓存·intellij-idea
wind瑞15 分钟前
IntelliJ IDEA插件开发-代码补全插件入门开发
java·ide·intellij-idea
HappyAcmen16 分钟前
IDEA部署AI代写插件
java·人工智能·intellij-idea
马剑威(威哥爱编程)21 分钟前
读写锁分离设计模式详解
java·设计模式·java-ee
鸽鸽程序猿22 分钟前
【算法】【优选算法】前缀和(上)
java·算法·前缀和
修道-032323 分钟前
【JAVA】二、设计模式之策略模式
java·设计模式·策略模式
九圣残炎28 分钟前
【从零开始的LeetCode-算法】2559. 统计范围内的元音字符串数
java·算法·leetcode
当归102441 分钟前
若依项目-结构解读
java
hlsd#1 小时前
关于 SpringBoot 时间处理的总结
java·spring boot·后端
iiiiiankor1 小时前
C/C++内存管理 | new的机制 | 重载自己的operator new
java·c语言·c++