[jbossweb-commits] JBossWeb SVN: r2296 - branches/2.1.x/java/org/apache/tomcat/util/net/jsse.

jbossweb-commits at lists.jboss.org jbossweb-commits at lists.jboss.org
Tue Oct 29 14:06:11 EDT 2013


Author: dehort
Date: 2013-10-29 14:06:11 -0400 (Tue, 29 Oct 2013)
New Revision: 2296

Modified:
   branches/2.1.x/java/org/apache/tomcat/util/net/jsse/JSSESupport.java
Log:
JBPAPP-10895 - JBossWeb memory leak with using SSL + Java security manager


Modified: branches/2.1.x/java/org/apache/tomcat/util/net/jsse/JSSESupport.java
===================================================================
--- branches/2.1.x/java/org/apache/tomcat/util/net/jsse/JSSESupport.java	2013-10-28 13:12:01 UTC (rev 2295)
+++ branches/2.1.x/java/org/apache/tomcat/util/net/jsse/JSSESupport.java	2013-10-29 18:06:11 UTC (rev 2296)
@@ -23,6 +23,8 @@
 import java.net.SocketException;
 import java.security.cert.Certificate;
 import java.security.cert.CertificateFactory;
+import java.util.Map;
+import java.util.WeakHashMap;
 
 import javax.net.ssl.HandshakeCompletedEvent;
 import javax.net.ssl.HandshakeCompletedListener;
@@ -52,6 +54,8 @@
     
     private static org.jboss.logging.Logger log =
         org.jboss.logging.Logger.getLogger(JSSESupport.class);
+    private static final Map<SSLSession, Integer> keySizeCache =
+        new WeakHashMap<SSLSession, Integer>(10);
 
     protected SSLSocket ssl;
     protected SSLSession session;
@@ -195,7 +199,7 @@
         SSLSupport.CipherData c_aux[]=ciphers;
         if (session == null)
             return null;
-        Integer keySize = (Integer) session.getValue(KEY_SIZE_KEY);
+        Integer keySize = (Integer) keySizeCache.get(session);
         if (keySize == null) {
             int size = 0;
             String cipherSuite = session.getCipherSuite();
@@ -206,7 +210,7 @@
                 }
             }
             keySize = new Integer(size);
-            session.putValue(KEY_SIZE_KEY, keySize);
+            keySizeCache.put(session, keySize);
         }
         return keySize;
     }



More information about the jbossweb-commits mailing list