Interface SSLSessionContext
SSLSessionContext
represents a set of
SSLSession
s associated with a single entity. For example,
it could be associated with a server or client who participates in many
sessions concurrently.
Not all environments will contain session contexts. For example, stateless session resumption.
Session contexts may not contain all sessions. For example, stateless sessions are not stored in the session context.
There are SSLSessionContext
parameters that affect how
sessions are stored:
- Sessions can be set to expire after a specified time limit.
- The number of sessions that can be stored in context can be limited.
SSLSessionContext
can be listed.- Since:
- 1.4
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptionEnumeration
<byte[]> getIds()
Returns an Enumeration of all known session id's grouped under thisSSLSessionContext
.getSession
(byte[] sessionId) Returns theSSLSession
bound to the specified session id.int
Returns the size of the cache used for storingSSLSession
objects grouped under thisSSLSessionContext
.int
Returns the timeout limit ofSSLSession
objects grouped under thisSSLSessionContext
.void
setSessionCacheSize
(int size) Sets the size of the cache used for storingSSLSession
objects grouped under thisSSLSessionContext
.void
setSessionTimeout
(int seconds) Sets the timeout limit forSSLSession
objects grouped under thisSSLSessionContext
.
-
Method Details
-
getSession
Returns theSSLSession
bound to the specified session id.- Parameters:
sessionId
- the Session identifier- Returns:
- the
SSLSession
or null if the specified session id does not refer to a valid SSLSession. - Throws:
NullPointerException
- ifsessionId
is null.
-
getIds
Enumeration<byte[]> getIds()Returns an Enumeration of all known session id's grouped under thisSSLSessionContext
.Session contexts may not contain all sessions. For example, stateless sessions are not stored in the session context.
- Returns:
- an enumeration of all the Session id's
-
setSessionTimeout
void setSessionTimeout(int seconds) Sets the timeout limit forSSLSession
objects grouped under thisSSLSessionContext
.If the timeout limit is set to 't' seconds, a session exceeds the timeout limit 't' seconds after its creation time. When the timeout limit is exceeded for a session, the
SSLSession
object is marked so that future connections cannot resume or rejoin the session. Active sessions can continue to be used so long as resume and rejoin operations are not attempted. A check for sessions exceeding the timeout is made immediately whenever the timeout limit is changed for thisSSLSessionContext
.- API Note:
- Note that the JDK Implementation uses default values for both
the session cache size and timeout. See
getSessionCacheSize
andgetSessionTimeout
for more information. Applications should consider their performance requirements and override the defaults if necessary. - Parameters:
seconds
- the new session timeout limit in seconds; zero means there is no limit.- Throws:
IllegalArgumentException
- if the timeout specified is< 0
.- See Also:
-
getSessionTimeout
int getSessionTimeout()Returns the timeout limit ofSSLSession
objects grouped under thisSSLSessionContext
.If the timeout limit is set to 't' seconds, a session exceeds the timeout limit 't' seconds after its creation time. When the timeout limit is exceeded for a session, the
SSLSession
object is marked so that future connections cannot resume or rejoin the session. Active sessions can continue to be used so long as resume and rejoin operations are not attempted. A check for sessions exceeding the timeout limit is made immediately whenever the timeout limit is changed for thisSSLSessionContext
.- Implementation Note:
- The JDK implementation returns the session timeout as set by
the
setSessionTimeout
method, or if not set, a default value of 86400 seconds (24 hours). - Returns:
- the session timeout limit in seconds; zero means there is no limit.
- See Also:
-
setSessionCacheSize
void setSessionCacheSize(int size) Sets the size of the cache used for storingSSLSession
objects grouped under thisSSLSessionContext
.- API Note:
- Note that the JDK Implementation uses default values for both
the session cache size and timeout. See
getSessionCacheSize
andgetSessionTimeout
for more information. Applications should consider their performance requirements and override the defaults if necessary. - Parameters:
size
- the new session cache size limit; zero means there is no limit.- Throws:
IllegalArgumentException
- if the specified size is< 0
.- See Also:
-
getSessionCacheSize
int getSessionCacheSize()Returns the size of the cache used for storingSSLSession
objects grouped under thisSSLSessionContext
.- Implementation Note:
- The JDK implementation returns the cache size as set by
the
setSessionCacheSize
method, or if not set, the value of thejavax.net.ssl.sessionCacheSize
system property. If neither is set, it returns a default value of 20480. - Returns:
- size of the session cache; zero means there is no size limit.
- See Also:
-