Не удается переопределить метод onAuthenticationSuccess для AuthenticationSuccessHandler
После некоторых других публикаций я попытался переопределить метод успешной аутентификации обработчика Spring-Security, но он никогда не вызывался. Мой код выглядит так:
src/groovy/mypackage/MyAuthenticationSuccessHandler.groovy
:
package mypackage
import org.springframework.security.core.Authentication
import org.springframework.security.web.authentication.SavedRequestAwareAuthenticationSuccessHandler
import javax.servlet.ServletException
import javax.servlet.http.HttpServletRequest
import javax.servlet.http.HttpServletResponse
public class MyAuthenticationSuccessHandler extends SavedRequestAwareAuthenticationSuccessHandler {
public MyAuthenticationSuccessHandler() {
println("constructed!")
}
@Override
public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication) throws ServletException, IOException {
println("override called")
super.onAuthenticationSuccess(request, response, authentication);
}
}
resources.groovy:
authenticationSuccessHandler(MyAuthenticationSuccessHandler) {
def conf = SpringSecurityUtils.securityConfig
requestCache = ref('requestCache')
defaultTargetUrl = conf.successHandler.defaultTargetUrl
alwaysUseDefaultTargetUrl = conf.successHandler.alwaysUseDefault
targetUrlParameter = conf.successHandler.targetUrlParameter
useReferer = conf.successHandler.useReferer
redirectStrategy = ref('redirectStrategy')
}
Там нет ошибок, конструктор определенно вызывается и MyAuthenticationSuccessHandler
вводится в тестовый контроллер, но onAuthenticationSuccess
никогда не называется. Я поместил точку останова в версию суперкласса, и это сработало. Я также попытался переписать свой пользовательский класс в Java, но это не сработало.
Что я делаю неправильно?
1 ответ
Оказалось, что другой фильтр входа в систему уже был активен, и это мешало нормальному методу работать. Рассматриваемый фильтр org.mitre.openid.connect.client.OIDCAuthenticationFilter
и обходной путь - ввести ваш обработчик успеха через него, например:
authenticationSuccessHandler(apipulse.MyAuthenticationSuccessHandler) {
clientRegistrationTemplate = ref(clientRegistrationTemplate)
}
...
openIdConnectAuthenticationFilter(OIDCAuthenticationFilter) {
...
authenticationSuccessHandler = ref('authenticationSuccessHandler')
}
Просто потратил впустую день, глядя на это - спасибо большое, весна.