From 38e9e8ca52ddc4bdd272083563a657d5e37ea1e8 Mon Sep 17 00:00:00 2001 From: Rob Winch Date: Thu, 28 Jan 2021 16:54:32 -0600 Subject: [PATCH] Optimize HttpSessionSecurityContextRepository Closes gh-9387 --- .../HttpSessionSecurityContextRepository.java | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/web/src/main/java/org/springframework/security/web/context/HttpSessionSecurityContextRepository.java b/web/src/main/java/org/springframework/security/web/context/HttpSessionSecurityContextRepository.java index 85f90e3f59..21719089fd 100644 --- a/web/src/main/java/org/springframework/security/web/context/HttpSessionSecurityContextRepository.java +++ b/web/src/main/java/org/springframework/security/web/context/HttpSessionSecurityContextRepository.java @@ -142,13 +142,7 @@ public class HttpSessionSecurityContextRepository implements SecurityContextRepo + response + ". You must use the HttpRequestResponseHolder.response after invoking loadContext"); } - // saveContext() might already be called by the response wrapper - // if something in the chain called sendError() or sendRedirect(). This ensures we - // only call it - // once per request. - if (!responseWrapper.isContextSaved()) { - responseWrapper.saveContext(context); - } + responseWrapper.saveContext(context); } public boolean containsContext(HttpServletRequest request) { @@ -305,6 +299,7 @@ public class HttpSessionSecurityContextRepository implements SecurityContextRepo private final boolean httpSessionExistedAtStartOfRequest; private final SecurityContext contextBeforeExecution; private final Authentication authBeforeExecution; + private boolean isSaveContextInvoked; /** * Takes the parameters required to call saveContext() successfully @@ -355,6 +350,7 @@ public class HttpSessionSecurityContextRepository implements SecurityContextRepo // SEC-1587 A non-anonymous context may still be in the session // SEC-1735 remove if the contextBeforeExecution was not anonymous httpSession.removeAttribute(springSecurityContextKey); + this.isSaveContextInvoked = true; } return; } @@ -371,7 +367,7 @@ public class HttpSessionSecurityContextRepository implements SecurityContextRepo if (contextChanged(context) || httpSession.getAttribute(springSecurityContextKey) == null) { httpSession.setAttribute(springSecurityContextKey, context); - + this.isSaveContextInvoked = true; if (logger.isDebugEnabled()) { logger.debug("SecurityContext '" + context + "' stored to HttpSession: '" + httpSession); @@ -381,7 +377,7 @@ public class HttpSessionSecurityContextRepository implements SecurityContextRepo } private boolean contextChanged(SecurityContext context) { - return context != contextBeforeExecution + return this.isSaveContextInvoked || context != contextBeforeExecution || context.getAuthentication() != authBeforeExecution; }