【OAuth2】Spring Security OAuth2 源码分析

要点

Spring Security OAuth2 主要有两部分功能:

  1. 生成token
  2. 验证token

对大概的流程进行了一次梳理

Server端生成token (post /oauth/token)

在这里插入图片描述

AuthorizationServerSecurityConfigurer在配置阶段 如果允许form表单提交则会经过ClientCredentialsTokenEndpointFilter, 剩下的流程可以总结为生成token、存储token。

  1. 生成token:按类型生成token,类型与oauth2四种授权类型(授权码、隐藏式、密码式、凭证式)相对应
  2. 存储token: 支持 内存、redis、数据库、等多种方式

Resource端验证token (访问受限接口)

在这里插入图片描述

ResourceSecurityConfigurer在配置阶段,对Resource进行配置,OAuth2核心过滤器 OAuth2AuthenticationProcessingFilter,如果请求中存在token 则进行验证,如果不存在则不验证(但是Spring Security会对接口权限进行验证)。

存在token流程

  1. 根据配置的userInfoEndpointUrlserver获取token的授权信息OAuthAuthentication
  2. 根据返回结果判断token是否有效(如果返回结果中存在error表明访问限制: 也就是说server对无效的token进行处理后,一定要返回非200的http响应Resource才能认定无效

本文转载自博客园作者**浮生半日**的Spring Security OAuth2 源码分析一文。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值