From a808cfb80ee3ed412976b07c085a964ffb99ede4 Mon Sep 17 00:00:00 2001 From: Markus Jung Date: Mon, 14 Feb 2022 15:04:11 +0100 Subject: [PATCH] Fix custom Principal deserialization (#443) --- .../src/main/java/de/javakaffee/web/msm/TranscoderService.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/core/src/main/java/de/javakaffee/web/msm/TranscoderService.java b/core/src/main/java/de/javakaffee/web/msm/TranscoderService.java index b0db00e4..c3c3a8b4 100644 --- a/core/src/main/java/de/javakaffee/web/msm/TranscoderService.java +++ b/core/src/main/java/de/javakaffee/web/msm/TranscoderService.java @@ -41,6 +41,7 @@ import org.apache.catalina.Session; import org.apache.catalina.authenticator.Constants; import org.apache.catalina.authenticator.SavedRequest; +import org.apache.catalina.util.CustomObjectInputStream; import org.apache.juli.logging.Log; import org.apache.juli.logging.LogFactory; import org.apache.tomcat.util.buf.ByteChunk; @@ -361,7 +362,7 @@ private static Principal deserializePrincipal( final byte[] data, final SessionM ObjectInputStream ois = null; try { bis = new ByteArrayInputStream( data ); - ois = new ObjectInputStream( bis ); + ois = new CustomObjectInputStream( bis, manager.getContainerClassLoader() ); return manager.readPrincipal( ois ); } catch ( final IOException e ) { throw new IllegalArgumentException( "Could not deserialize principal", e );