首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Spring Authorization Server 0.2.3发布,增加联合身份认证DEMO

Spring Authorization Server 0.2.3发布,增加联合身份认证DEMO

作者头像
码农小胖哥
发布2022-04-06 13:57:11
发布2022-04-06 13:57:11
9640
举报

很快啊Spring Authorization Server又发新版本了,现在的版本是0.2.3。本次都有什么改动呢?我们来了解一下。

0.2.3版本特性

本次更新的新特性不少。

为公开客户端提供默认的设置

根据RFC6479,包含授权码(authorization_code)授权并且客户端认证方式ClientAuthenticationMethod只有一种,为none的客户端都是公开(Public)客户端,反之就是机密(Confidential)客户端。

0.2.3中,为公开的客户端提供了客户端默认配置ClientSettings

代码语言:javascript
复制
   if (this.clientSettings == null) {
    ClientSettings.Builder builder = ClientSettings.builder();
    if (isPublicClientType()) {
     // @formatter:off
     builder
       .requireProofKey(true)
       .requireAuthorizationConsent(true);
     // @formatter:on
    }
    this.clientSettings = builder.build();
   }

这里多说点,公开客户端现在不单纯是authorization_code模式授权,必须加上PKCE,关于什么是PKCE可以通过我的专栏[1]进行了解。

OAuth2ClientAuthenticationProvider被细分

Spring Authorization Server目前支持的客户端认证方式有:

  • client_secret_basic
  • client_secret_post
  • client_secret_jwt
  • private_key_jwt
  • none

之前由OAuth2ClientAuthenticationProvider 一手包办,现在职责分离了。

JwtClientAssertionAuthenticationProvider

负责private_key_jwtclient_secret_jwt,具体细节请关注我的专栏。目前胖哥已经实现了完整的private_key_jwt认证的DEMO[2]

ClientSecretAuthenticationProvider

默认的client_secret_basicclient_secret_post由它负责。

PublicClientAuthenticationProvider

处理上面所说的公开客户端的认证方式。

InMemoryOAuth2AuthorizationService优化

主要优化了对未完成授权信息OAuth2Authorization存储的淘汰策略,如果内存中存储的数量超过100,会把最老存储的信息淘汰掉。

增加了联合身份的DEMO

Federated Identity Pattern (联合身份模式)举个例子,你同时对接了好几个身份提供商(IDP),你都需要跳不同的授权服务器页面并输入对应的密码,现在这些IDP可以都放在Spring Authorization Server下面,委托给Spring Authorization Server来处理身份认证授权。这样你不用跳来跳去了,只需要维护Spring Authorization ServerIDP的关系了。

本次增加了相关的DEMO,请注意该功能不是Spring Authorization Server本身自带的功能。

OAuth2TokenGenerator

0.2.3抽象了OAuth2Token的的生成模型:

代码语言:javascript
复制
@FunctionalInterface
public interface OAuth2TokenGenerator<T extends OAuth2Token> {
 
 @Nullable
 T generate(OAuth2TokenContext context);

}
OAuth2授权码使用统一的Token生成模型

授权码授权中的code的生成现在也需要由OAuth2TokenGenerator实现,实现类为OAuth2AuthorizationCodeGenerator

OAuth2刷新Token使用统一的Token生成模型

OAuth2刷新令牌 OAuth2RefreshToken现在同样需要由OAuth2TokenGenerator实现。

JWT的生成使用统一的模型

现在JWT的生成也由OAuth2TokenGenerator来实现,具体的实现类为JwtGenerator

支持不透明令牌

现在你可以自定义一个OAuth2TokenGenerator并注入到Spring IoC来实现自定义的令牌生成逻辑,这意味着不透明令牌也可以通过自定义来实现。

令牌自省过滤器配置现在可以自定义

0.2.3版本之前令牌自省[3]的配置由OAuth2AuthorizationServerConfigurer负责,现在它由独立的配置类OAuth2TokenIntrospectionEndpointConfigurer负责。

依赖升级

0.2.3也对部分的依赖进行了升级,具体为:

  • 更新到Reactor 2020.0.16
  • 更新到Spring Security 5.5.5
  • 更新到Spring Framework 5.3.16
  • 更新到Spring Boot 2.5.10

❝胖哥也将持续跟进,对依赖进行逐步升级。

参考资料

[1]

我的专栏: https://blog.csdn.net/qq_35067322/category_11691173.html

[2]

DEMO: https://gitee.com/felord/spring-security-oauth2-tutorial

[3]

令牌自省的配置: https://felord.blog.csdn.net/article/details/123634847

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-03-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码农小胖哥 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 0.2.3版本特性
    • 为公开客户端提供默认的设置
    • OAuth2ClientAuthenticationProvider被细分
      • JwtClientAssertionAuthenticationProvider
      • ClientSecretAuthenticationProvider
      • PublicClientAuthenticationProvider
    • InMemoryOAuth2AuthorizationService优化
    • 增加了联合身份的DEMO
    • OAuth2TokenGenerator
      • OAuth2授权码使用统一的Token生成模型
      • OAuth2刷新Token使用统一的Token生成模型
      • JWT的生成使用统一的模型
      • 支持不透明令牌
    • 令牌自省过滤器配置现在可以自定义
  • 依赖升级
    • 参考资料
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档