网站首页 > java教程 正文
背景和需求:
一个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),之后进行鉴权(访问控制权限)逻辑,成功后继续执行后续业务;
注:因涉及版权,代码就不贴了,只谈技术,实在抱歉~
猜你喜欢
- 2024-11-10 面试Java多线程安全问题(面试java多线程安全问题答案)
- 2024-11-10 实战解析居安思危的Redis拓展—保护Redis,为Redis安全保驾护航
- 2024-11-10 Java线程安全(java线程安全是什么)
- 2024-11-10 JAVA应用程序集成控件JxBrowser v7.2来啦!允许自定义错误页面
- 2024-11-10 用了SpringSecurity后怎么全是403Forbidden了
- 2024-11-10 Java安全之初探weblogic T3协议漏洞
- 2024-11-10 快速云:如果自己的服务器受到攻击怎么办?
- 2024-11-10 如何在字节码层面实现方法拦截:探索 Java Agent 与 ASM 的魅力
- 2024-11-10 什么是Java线程安全?(java的线程安全是什么意思)
- 2024-11-10 【基本功】Java魔法类:Unsafe应用解析
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)