2
0

authentication.adoc 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. = Authentication Migrations
  2. The following steps relate to how to finish migrating authentication support.
  3. == Propagate ``AuthenticationServiceException``s
  4. {security-api-url}org/springframework/security/web/authentication/AuthenticationFilter.html[`AuthenticationFilter`] propagates {security-api-url}org/springframework/security/authentication/AuthenticationServiceException.html[``AuthenticationServiceException``]s to the {security-api-url}org/springframework/security/web/AuthenticationEntryPoint.html[`AuthenticationEntryPoint`].
  5. Because ``AuthenticationServiceException``s represent a server-side error instead of a client-side error, in 6.0, this changes to propagate them to the container.
  6. So, if you opted into this behavior by setting `rethrowAuthenticationServiceException` to `true`, you can now remove it like so:
  7. [tabs]
  8. ======
  9. Java::
  10. +
  11. [source,java,role="primary"]
  12. ----
  13. AuthenticationFilter authenticationFilter = new AuthenticationFilter(...);
  14. AuthenticationEntryPointFailureHandler handler = new AuthenticationEntryPointFailureHandler(...);
  15. handler.setRethrowAuthenticationServiceException(true);
  16. authenticationFilter.setAuthenticationFailureHandler(handler);
  17. ----
  18. Kotlin::
  19. +
  20. [source,kotlin,role="secondary"]
  21. ----
  22. val authenticationFilter: AuthenticationFilter = AuthenticationFilter(...)
  23. val handler: AuthenticationEntryPointFailureHandler = AuthenticationEntryPointFailureHandler(...)
  24. handler.setRethrowAuthenticationServiceException(true)
  25. authenticationFilter.setAuthenticationFailureHandler(handler)
  26. ----
  27. Xml::
  28. +
  29. [source,xml,role="secondary"]
  30. ----
  31. <bean id="authenticationFilter" class="org.springframework.security.web.authentication.AuthenticationFilter">
  32. <!-- ... -->
  33. <property ref="authenticationFailureHandler"/>
  34. </bean>
  35. <bean id="authenticationFailureHandler" class="org.springframework.security.web.authentication.AuthenticationEntryPointFailureHandler">
  36. <property name="rethrowAuthenticationServiceException" value="true"/>
  37. </bean>
  38. ----
  39. ======
  40. changes to:
  41. [tabs]
  42. ======
  43. Java::
  44. +
  45. [source,java,role="primary"]
  46. ----
  47. AuthenticationFilter authenticationFilter = new AuthenticationFilter(...);
  48. AuthenticationEntryPointFailureHandler handler = new AuthenticationEntryPointFailureHandler(...);
  49. authenticationFilter.setAuthenticationFailureHandler(handler);
  50. ----
  51. Kotlin::
  52. +
  53. [source,kotlin,role="secondary"]
  54. ----
  55. val authenticationFilter: AuthenticationFilter = AuthenticationFilter(...)
  56. val handler: AuthenticationEntryPointFailureHandler = AuthenticationEntryPointFailureHandler(...)
  57. authenticationFilter.setAuthenticationFailureHandler(handler)
  58. ----
  59. Xml::
  60. +
  61. [source,xml,role="secondary"]
  62. ----
  63. <bean id="authenticationFilter" class="org.springframework.security.web.authentication.AuthenticationFilter">
  64. <!-- ... -->
  65. <property ref="authenticationFailureHandler"/>
  66. </bean>
  67. <bean id="authenticationFailureHandler" class="org.springframework.security.web.authentication.AuthenticationEntryPointFailureHandler">
  68. <!-- ... -->
  69. </bean>
  70. ----
  71. ======
  72. [[servlet-opt-in-sha256-rememberme]]
  73. == Use SHA-256 in Remember Me
  74. In 6.0, the `TokenBasedRememberMeServices` uses SHA-256 to encode and match the token.
  75. To complete the migration, any default values can be removed.
  76. For example, if you opted in to the 6.0 default for `encodingAlgorithm` and `matchingAlgorithm` like so:
  77. [tabs]
  78. ======
  79. Java::
  80. +
  81. [source,java,role="primary"]
  82. ----
  83. @Configuration
  84. @EnableWebSecurity
  85. public class SecurityConfig {
  86. @Bean
  87. SecurityFilterChain securityFilterChain(HttpSecurity http, RememberMeServices rememberMeServices) throws Exception {
  88. http
  89. // ...
  90. .rememberMe((remember) -> remember
  91. .rememberMeServices(rememberMeServices)
  92. );
  93. return http.build();
  94. }
  95. @Bean
  96. RememberMeServices rememberMeServices(UserDetailsService userDetailsService) {
  97. RememberMeTokenAlgorithm encodingAlgorithm = RememberMeTokenAlgorithm.SHA256;
  98. TokenBasedRememberMeServices rememberMe = new TokenBasedRememberMeServices(myKey, userDetailsService, encodingAlgorithm);
  99. rememberMe.setMatchingAlgorithm(RememberMeTokenAlgorithm.SHA256);
  100. return rememberMe;
  101. }
  102. }
  103. ----
  104. XML::
  105. +
  106. [source,xml,role="secondary"]
  107. ----
  108. <http>
  109. <remember-me services-ref="rememberMeServices"/>
  110. </http>
  111. <bean id="rememberMeServices" class=
  112. "org.springframework.security.web.authentication.rememberme.TokenBasedRememberMeServices">
  113. <property name="userDetailsService" ref="myUserDetailsService"/>
  114. <property name="key" value="springRocks"/>
  115. <property name="matchingAlgorithm" value="SHA256"/>
  116. <property name="encodingAlgorithm" value="SHA256"/>
  117. </bean>
  118. ----
  119. ======
  120. then the defaults can be removed:
  121. [tabs]
  122. ======
  123. Java::
  124. +
  125. [source,java,role="primary"]
  126. ----
  127. @Configuration
  128. @EnableWebSecurity
  129. public class SecurityConfig {
  130. @Bean
  131. SecurityFilterChain securityFilterChain(HttpSecurity http, RememberMeServices rememberMeServices) throws Exception {
  132. http
  133. // ...
  134. .rememberMe((remember) -> remember
  135. .rememberMeServices(rememberMeServices)
  136. );
  137. return http.build();
  138. }
  139. @Bean
  140. RememberMeServices rememberMeServices(UserDetailsService userDetailsService) {
  141. return new TokenBasedRememberMeServices(myKey, userDetailsService);
  142. }
  143. }
  144. ----
  145. XML::
  146. +
  147. [source,xml,role="secondary"]
  148. ----
  149. <http>
  150. <remember-me services-ref="rememberMeServices"/>
  151. </http>
  152. <bean id="rememberMeServices" class=
  153. "org.springframework.security.web.authentication.rememberme.TokenBasedRememberMeServices">
  154. <property name="userDetailsService" ref="myUserDetailsService"/>
  155. <property name="key" value="springRocks"/>
  156. </bean>
  157. ----
  158. ======
  159. == Default authorities for oauth2Login()
  160. In Spring Security 5, the default `GrantedAuthority` given to a user that authenticates with an OAuth2 or OpenID Connect 1.0 provider (via `oauth2Login()`) is `ROLE_USER`.
  161. In Spring Security 6, the default authority given to a user authenticating with an OAuth2 provider is `OAUTH2_USER`.
  162. The default authority given to a user authenticating with an OpenID Connect 1.0 provider is `OIDC_USER`.
  163. If you configured the `GrantedAuthoritiesMapper` only for the purpose of updating to 6.0, you can remove it completely.