Java,SpringSecurity,支持多个端认证和授权

createh52个月前 (05-08)技术教程33

背景和需求:

一个SpringBoot项目,认证授权采用:SpringSecurity+Token(JWT)支持Web端,现需要同时并行的支持其它端的认证授权。

SpringSecurity

SpringSecurity中的filter链:

SpringSecurity中常用的类:

1、Authentication,认证对象,认证请求时组装成该对象;

2、AuthenticationManager,认证管理器,处理身份验证请求,返回一个Authentication对象,发生异常抛出AuthenticationException;

3、ProviderManager,认证提供者管理器,对认证请求链进行管理;

4、AuthenticationProvider,认证提供者,表明支持认证类型,进行认证逻辑处理;

5、UserDetailsService,用户信息服务对象;

6、UserDetails,用户信息对象;

其他相关:

Java,安全,JWT,jjwt,token应用案例Java,安全,JWT,java-jwt,token应用案例Java,SpringBoot采用token方式实现登录认证

改造方案:

认证改造(流程和逻辑),
UsernamePasswordAuthenticationFilter拦截:

1、attemptAuthentication()方法,执行解析认证JSON参数,构造【Authentication,认证对象(已添加客户端类型:clientType)】,调用:AuthenticationManager,认证管理器】的authenticate()方法,【AuthenticationManager】调用了【ProviderManager】的authenticate()方法,方法中遍历【AuthenticationProvider,认证提供者】,找到合适(支持)的【AuthenticationProvider,认证提供者】,【AuthenticationProvider,认证提供者】进行认证(逻辑处理),认证时参数:clientType、username、password,最终【Authentication】对象;

2、successfulAuthentication()方法,取到【Authentication】,根据clientType、username生成token,以JSON(application/json)返回客户端;

授权改造(流程和逻辑),BasicAuthenticationFilter拦截:

doFilterInternal()方法,从request取头参数:Authorization,取到token,解析并验证,token中含有:clientType、username,可分情况处理,构造成
UsernamePasswordAuthenticationToken对象,设置:
SecurityContextHolder.getContext().setAuthentication(authenticationToken),之后进行鉴权(访问控制权限)逻辑,成功后继续执行后续业务;

注:因涉及版权,代码就不贴了,只谈技术,实在抱歉~

相关文章

JWT在Java项目中的认证实践:从零开始打造安全高效的登录系统

JWT在Java项目中的认证实践:从零开始打造安全高效的登录系统在现代互联网开发中,安全认证是构建可靠系统的基石。而JSON Web Token(JWT)作为一种轻量级的认证机制,因其高效便捷的特点被...

OAuth2协议在实际项目中的应用:为你的应用添加“社交登录”功能

OAuth2协议在实际项目中的应用:为你的应用添加“社交登录”功能OAuth2协议在现代Web开发中扮演着至关重要的角色,它就像一把钥匙,帮你打开安全授权的大门。今天,我们就来聊聊OAuth2协议在实...

Java 自定义注解在登录验证的应用

java注解从 JDK 5开始,Java 增加了注解的新功能,注解其实是代码里面的特殊标记,这些标记可以在编译、类加载和运行时被读取,在不改变代码原有逻辑下,给源文件嵌入注解信息。再通过返回获取注解信...

Java登录暗藏玄机!5年开发老鸟揭秘7大安全漏洞—附终极防御方案

“你的用户密码真的安全吗?80%的Java开发者都踩过这些坑!悟空问答特邀资深架构师,用外卖系统等生活案例,教你写出支付宝级别的登录系统!”一、灵魂拷问:记住我功能=记住危险?用户提问:“为什么我用C...

Spring Boot3 扫码登录实现全解析:从基础到实战

登录环节作为用户与应用交互的第一步,其便捷性和安全性备受关注。扫码登录以其高效、便捷的特性,正逐渐成为众多应用的标配。对于后端开发人员而言,在 Spring Boot3 框架下实现扫码登录,既充满挑战...

微信小程序扫码登录的实现(微信小程序实现扫码功能)

上海天正信息科技有限公司Topcheer-AM数智运管平台-提供IT运维产品与服务二维码扫描登录是一种便捷的登录方式,用户通过使用移动设备扫描电脑端显示的二维码,即可快速登录系统,无需手动输入用户名和...