跳到主要内容

OAuth 2.0 客户端

QWen Max 中英对照 OAuth2 Client OAuth 2.0 Client

OAuth 2.0 客户端功能为 OAuth 2.0 授权框架中定义的客户端角色提供支持。

在高层次上,可用的核心功能包括:

授权许可支持

客户端认证支持

HTTP 客户端支持

ServerHttpSecurity.oauth2Client() DSL 提供了多个配置选项,用于自定义 OAuth 2.0 客户端使用的核心组件。

以下代码展示了 ServerHttpSecurity.oauth2Client() DSL 提供的完整配置选项:

@Configuration
@EnableWebFluxSecurity
public class OAuth2ClientSecurityConfig {

@Bean
public SecurityWebFilterChain securityWebFilterChain(ServerHttpSecurity http) {
http
.oauth2Client(oauth2 -> oauth2
.clientRegistrationRepository(this.clientRegistrationRepository())
.authorizedClientRepository(this.authorizedClientRepository())
.authorizationRequestRepository(this.authorizationRequestRepository())
.authorizationRequestResolver(this.authorizationRequestResolver())
.authenticationConverter(this.authenticationConverter())
.authenticationManager(this.authenticationManager())
);

return http.build();
}
}
java

ReactiveOAuth2AuthorizedClientManager 负责管理 OAuth 2.0 客户端的授权(或重新授权),并与一个或多个 ReactiveOAuth2AuthorizedClientProvider 协同工作。

以下代码展示了如何注册一个 ReactiveOAuth2AuthorizedClientManager @Bean,并将其与一个 ReactiveOAuth2AuthorizedClientProvider 组合关联,该组合支持 authorization_coderefresh_tokenclient_credentialspassword 授权类型:

@Bean
public ReactiveOAuth2AuthorizedClientManager authorizedClientManager(
ReactiveClientRegistrationRepository clientRegistrationRepository,
ServerOAuth2AuthorizedClientRepository authorizedClientRepository) {

ReactiveOAuth2AuthorizedClientProvider authorizedClientProvider =
ReactiveOAuth2AuthorizedClientProviderBuilder.builder()
.authorizationCode()
.refreshToken()
.clientCredentials()
.password()
.build();

DefaultReactiveOAuth2AuthorizedClientManager authorizedClientManager =
new DefaultReactiveOAuth2AuthorizedClientManager(
clientRegistrationRepository, authorizedClientRepository);
authorizedClientManager.setAuthorizedClientProvider(authorizedClientProvider);

return authorizedClientManager;
}
java

章节摘要