使用 ClientRegistrationId 作为请求属性的 WebClient(使用 OAuth 2.0)

Tim*_*dit 4 java rest webclient oauth-2.0 spring-boot

我正在寻找一个工作示例,当我将请求属性添加到 WebClient 时,我可以在其中设置 ClientRegistrationId。spring.io 提供的示例对我不起作用(docs.spring.io (5.2.12))。

当我尝试这个示例时(使用默认的 ClientRegistrationId):

@Bean
WebClient webClient(ReactiveClientRegistrationRepository clientRegistrations,
        ServerOAuth2AuthorizedClientRepository authorizedClients) {
    ServerOAuth2AuthorizedClientExchangeFilterFunction oauth =
            new ServerOAuth2AuthorizedClientExchangeFilterFunction(clientRegistrations, authorizedClients);
    // (optional) explicitly opt into using the oauth2Login to provide an access token implicitly
    // oauth.setDefaultOAuth2AuthorizedClient(true);
    // (optional) set a default ClientRegistration.registrationId
    oauth.setDefaultClientRegistrationId("MyClRegId");
    return WebClient.builder()
            .filter(oauth)
            .build();
}
Run Code Online (Sandbox Code Playgroud)

调用端点:

ResponseSpec responseSpec = this.webClient.get().uri("/NumberOrders").retrieve();
Run Code Online (Sandbox Code Playgroud)

应用.属性:

spring.security.oauth2.client.registration.MyClRegId.authorization-grant-type=client_credentials
spring.security.oauth2.client.registration.MyClRegId.client-id=myteam
spring.security.oauth2.client.registration.MyClRegId.client-secret=12349875
spring.security.oauth2.client.provider.MyClRegId.token-uri=https://something/token
spring.security.oauth2.client.registration.MyClRegId.scope=OIDC
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

引起原因:java.lang.IllegalArgumentException:serverWebExchange 不能为 null

如果我尝试将 ClientRegistrationId 设置为请求属性,相应的 spring.io 示例(docs.spring.io (5.2.12))会发生另一个错误(方法 clientRegistrationId(String) 未定义...):

ResponseSpec responseSpec = this.webClient
        .get()
        .attributes(clientRegistrationId("client-id"))
        .uri("/NumberOrders")
        .retrieve();
Run Code Online (Sandbox Code Playgroud)

这个错误并不奇怪,因为该方法确实不存在,但是有人有这样的方法的示例吗?属性需要Consumer<Map<String, Object>> attributeConsumer作为输入来设置 ClientRegistrationId。当然,它应该可以正常工作而不会出现第一个错误(serverWebExchange 不能为 null)。

我在这里找到了一个工作设置WebClient OAuth2(由clocken回答),但是ClientRegistrationId是在Bean中设置的。我想在调用端点时设置它。因此,我可以在 application.properties 中使用不同的配置(具有不同的 ClientRegistrationIds)。

也许有一种方法可以在设置 WebClient.Builder 时设置 ClientRegistrationId?

我搜索了很多,但找不到任何答案。提前感谢您的帮助。

我正在使用这个依赖项:

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.5.4</version>
    <relativePath />
</parent>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-oauth2-client</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
Run Code Online (Sandbox Code Playgroud)

小智 5

您可以使用

  webClient.get()
  .uri("http://localhost:8084/retrieve-resource")
  .attributes(
    ServerOAuth2AuthorizedClientExchangeFilterFunction
      .clientRegistrationId("bael"))
  .retrieve()
  // ...
Run Code Online (Sandbox Code Playgroud)

这是完整的代码: https: //www.baeldung.com/spring-webclient-oauth2