2
0

index.adoc 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. [[oauth2client]]
  2. = OAuth 2.0 Client
  3. :page-section-summary-toc: 1
  4. The OAuth 2.0 Client features provide support for the Client role as defined in the https://tools.ietf.org/html/rfc6749#section-1.1[OAuth 2.0 Authorization Framework].
  5. At a high-level, the core features available are:
  6. .Authorization Grant support
  7. * https://tools.ietf.org/html/rfc6749#section-1.3.1[Authorization Code]
  8. * https://tools.ietf.org/html/rfc6749#section-6[Refresh Token]
  9. * https://tools.ietf.org/html/rfc6749#section-1.3.4[Client Credentials]
  10. * https://tools.ietf.org/html/rfc6749#section-1.3.3[Resource Owner Password Credentials]
  11. * https://datatracker.ietf.org/doc/html/rfc7523#section-2.1[JWT Bearer]
  12. .Client Authentication support
  13. * https://datatracker.ietf.org/doc/html/rfc7523#section-2.2[JWT Bearer]
  14. .HTTP Client support
  15. * xref:servlet/oauth2/client/authorized-clients.adoc#oauth2Client-webclient-servlet[`WebClient` integration for Servlet Environments] (for requesting protected resources)
  16. The `HttpSecurity.oauth2Client()` DSL provides a number of configuration options for customizing the core components used by OAuth 2.0 Client.
  17. In addition, `HttpSecurity.oauth2Client().authorizationCodeGrant()` enables the customization of the Authorization Code grant.
  18. The following code shows the complete configuration options provided by the `HttpSecurity.oauth2Client()` DSL:
  19. .OAuth2 Client Configuration Options
  20. [tabs]
  21. ======
  22. Java::
  23. +
  24. [source,java,role="primary"]
  25. ----
  26. @EnableWebSecurity
  27. public class OAuth2ClientSecurityConfig extends WebSecurityConfigurerAdapter {
  28. @Override
  29. protected void configure(HttpSecurity http) throws Exception {
  30. http
  31. .oauth2Client(oauth2 -> oauth2
  32. .clientRegistrationRepository(this.clientRegistrationRepository())
  33. .authorizedClientRepository(this.authorizedClientRepository())
  34. .authorizedClientService(this.authorizedClientService())
  35. .authorizationCodeGrant(codeGrant -> codeGrant
  36. .authorizationRequestRepository(this.authorizationRequestRepository())
  37. .authorizationRequestResolver(this.authorizationRequestResolver())
  38. .accessTokenResponseClient(this.accessTokenResponseClient())
  39. )
  40. );
  41. }
  42. }
  43. ----
  44. Kotlin::
  45. +
  46. [source,kotlin,role="secondary"]
  47. ----
  48. @EnableWebSecurity
  49. class OAuth2ClientSecurityConfig : WebSecurityConfigurerAdapter() {
  50. override fun configure(http: HttpSecurity) {
  51. http {
  52. oauth2Client {
  53. clientRegistrationRepository = clientRegistrationRepository()
  54. authorizedClientRepository = authorizedClientRepository()
  55. authorizedClientService = authorizedClientService()
  56. authorizationCodeGrant {
  57. authorizationRequestRepository = authorizationRequestRepository()
  58. authorizationRequestResolver = authorizationRequestResolver()
  59. accessTokenResponseClient = accessTokenResponseClient()
  60. }
  61. }
  62. }
  63. }
  64. }
  65. ----
  66. ======
  67. In addition to the `HttpSecurity.oauth2Client()` DSL, XML configuration is also supported.
  68. The following code shows the complete configuration options available in the xref:servlet/appendix/namespace/http.adoc#nsa-oauth2-client[ security namespace]:
  69. .OAuth2 Client XML Configuration Options
  70. [source,xml]
  71. ----
  72. <http>
  73. <oauth2-client client-registration-repository-ref="clientRegistrationRepository"
  74. authorized-client-repository-ref="authorizedClientRepository"
  75. authorized-client-service-ref="authorizedClientService">
  76. <authorization-code-grant
  77. authorization-request-repository-ref="authorizationRequestRepository"
  78. authorization-request-resolver-ref="authorizationRequestResolver"
  79. access-token-response-client-ref="accessTokenResponseClient"/>
  80. </oauth2-client>
  81. </http>
  82. ----
  83. The `OAuth2AuthorizedClientManager` is responsible for managing the authorization (or re-authorization) of an OAuth 2.0 Client, in collaboration with one or more `OAuth2AuthorizedClientProvider`(s).
  84. The following code shows an example of how to register an `OAuth2AuthorizedClientManager` `@Bean` and associate it with an `OAuth2AuthorizedClientProvider` composite that provides support for the `authorization_code`, `refresh_token`, `client_credentials` and `password` authorization grant types:
  85. [tabs]
  86. ======
  87. Java::
  88. +
  89. [source,java,role="primary"]
  90. ----
  91. @Bean
  92. public OAuth2AuthorizedClientManager authorizedClientManager(
  93. ClientRegistrationRepository clientRegistrationRepository,
  94. OAuth2AuthorizedClientRepository authorizedClientRepository) {
  95. OAuth2AuthorizedClientProvider authorizedClientProvider =
  96. OAuth2AuthorizedClientProviderBuilder.builder()
  97. .authorizationCode()
  98. .refreshToken()
  99. .clientCredentials()
  100. .password()
  101. .build();
  102. DefaultOAuth2AuthorizedClientManager authorizedClientManager =
  103. new DefaultOAuth2AuthorizedClientManager(
  104. clientRegistrationRepository, authorizedClientRepository);
  105. authorizedClientManager.setAuthorizedClientProvider(authorizedClientProvider);
  106. return authorizedClientManager;
  107. }
  108. ----
  109. Kotlin::
  110. +
  111. [source,kotlin,role="secondary"]
  112. ----
  113. @Bean
  114. fun authorizedClientManager(
  115. clientRegistrationRepository: ClientRegistrationRepository,
  116. authorizedClientRepository: OAuth2AuthorizedClientRepository): OAuth2AuthorizedClientManager {
  117. val authorizedClientProvider: OAuth2AuthorizedClientProvider = OAuth2AuthorizedClientProviderBuilder.builder()
  118. .authorizationCode()
  119. .refreshToken()
  120. .clientCredentials()
  121. .password()
  122. .build()
  123. val authorizedClientManager = DefaultOAuth2AuthorizedClientManager(
  124. clientRegistrationRepository, authorizedClientRepository)
  125. authorizedClientManager.setAuthorizedClientProvider(authorizedClientProvider)
  126. return authorizedClientManager
  127. }
  128. ----
  129. ======